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ABSTRACT 


In  most  shipboard  CIC's  true  motion  plots  of  own  ship 
and/or  surface/subsurface  contact  motions  are  performed 
with  the  aid  of  electromechanical  devices.  These  are 
inaccurate  and  have  a  variety  of  drawbacks. 

This  thesis  describes  a  fast,  labor-saving,  bearing 
only  radar  tracking  solution  utilizing  various  microprocessors 
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I .  INTRODUCTION 


Passive  localization  and  tracking  techniques  are  of 
interest  in  a  variety  of  microcomputer  based  surface/ 
subsurface  radar  applications. 

Because  a  significant  portion  of  the  cost  of  building 
or  maintaining  a  warship  is  the  electronics  in  its  sensor 
and  weapon  system,  and  because  a  great  amount  of  time  and 
manpower  is  employed  in  performing  simple  but  important 
tasks,  microcomputers  offer  the  potential  to: 

(1)  Reduce  the  cost  of  digital  systems, 

(2)  Perform  some  complex  functions  at  remote  stations, 
relieving  the  congestion  at  larger  central  computer 
facilities,  and 

(3)  Perform  functions  currently  handled  by  watch  personnel, 
thus  reducing  the  manning  requirements  of  watch 
sections. 

An  example  of  this  is  the  problem  of  manual  tracking  of  radar 
contacts  and  the  solution  of  Maneuvering  Board  Problems. 

It  is  the  purpose  of  this  study  to  demonstrate  than  an 
alternate  approach  to  the  solution  of  the  problems  mentioned 
above  can  be  developed  and  implemented  by  using  a  micro¬ 
computer  system,  while  at  the  same  time  maintaining  a  human 
engineered  user  interface. 

V 

‘  \ 
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II .  FORMULATION  OF  THE  PROBLEM 


A.  PREFACE 

For  Naval  ships  not  equipped  with  Naval  Tactical  Data 
Systems  (NTDS) ,  operations  performed  by  the  Combat  Infor¬ 
mation  Center  (CIC)  during  a  normal  peacetime  watch  include 
manual  tracking  of  radar  contacts  and  solution  of  maneuvering 
board  problems.  The  environment  emulated  by  the  Intel 
Intellec  Microcomputer  Development  System  (MDS)  provides  a 
data  subset  of  the  NTDS .  The  subset  of  information  is 
provided  via  radar  interface  to  the  MDS  System. 

The  interface  between  the  microcomputer  and  the  surface 
radar  was  not  constructed  to  due  cost,  time  and  manpower 
constraints. 

The  scenario  of  the  study  was  limited  to  the  development 
of  a  Kalman  Filter  bearing-only  tracking  algorithm  for  the 
Intel  Intellec  MDS  microcomputer  system  and  Intel  SBC- 310 
High-Speed  Mathematics  Unit  Performance.  Simulation  of  the 
circuitry  is  necessary  to  interface  with  the  AN/SPS-10 
surface  search  radar. 

The  parameters  for  the  AN/SPS-10  surface  search  radar 
were  used  for  computations  requiring  specific  radar 
parameters.  This  radar  was  chosen  because  all  information 
regarding  the  radar  is  available  at  the  Naval  Postgraduate 
School . 
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A  Kalman  filter  was  selected  because  it  minimizes  the 
estimation  error  in  a  well  defined  statistical  sense  and 
most  complex  calculations  of  the  tracking  filters  typically 
used  for  bearing-only  radar  tracking  that  is  easily 
computable  with  a  microcomputer  system. 

The  system  input/output  parameters  are  shown  in 
Figure  1. 

B.  TYPICAL  COMBAT  INFORMATION  CENTER  OPERATIONS 

During  normal  peacetime  steaming,  the  CIC  watch  team 
may  consist  of  from  two  to  ten  or  even  more  personnel, 
depending  on  the  size  of  the  ship  as  well  as  on  the  complexity 
of  the  equipment  being  used. 

Among  the  problems  that  are  normally  solved  by  CIC 
personnel,  special  mention  needs  to  be  made  of  those  of 
plotting  contacts  and  the  determination  of  parameters  such  as 
course,  speed  and  closest  point  of  approach  (CPA)  of  those 
contacts.  This  is  a  tedious  and  error-prone  task;  it  often 
requires  most  of  the  time  and  effort  of  the  CIC  team  and  it 
is  vitally  important  to  the  safety  of  the  ship.  This  had 
led  to  the  installation  of  equipment  to  reduce  the  amount 
of  workload  in  the  CIC  while  at  the  same  time  improving  the 
reliability  of  the  constant  information  provided  to  the 
bridge.  This  equipment  includes  dead  reckoning  devices  and 
NC2  plotter. 

1.  Maneuvering  Board  Plotting  Sheets 

The  maneuvering  Board  Plotting  Sheets  (H.O.  2665-10) 
have  been  prepared  in  order  to  facilitate  the  solution  of 
a  ship's  relative  movement  problem. 
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Figure  1.  SYSTEM  INPUT/OUTPUT  PARAMETERS 


The  primary  responsibility  of  CIC  is  to  provide 
information  and  recommendations  on  the  tactical  situations, 
such  as  contact  course,  speed,  CPA  information,  are  defined 
using  the  "Maneuvering  Board"  plotting  sheets.  But  the  use 
of  the  Maneuvering  Board  requires  some  pracice,  also  it 
requires  the  complete  attention  of  one  person  during  the 
CIC  operation. 

2.  Dead-Reckoning  Equipment 

This  equipment  maintains  a  continuous,  up  to  the 
minute,  geographic  plot  of  own  ship's  plot  in  the  CIC. 

The  Dead-Reckoning  System  consists  of  the  following 
basic  components:  (1)  Dead-Reckoning  Analyzer  (DRA) ; 

(2)  Dead-Reckoning  Indicator  (DRI);  and  (3)  Dead-Reckoning 
Time  (DRT) .  Course  and  speed  inputs  of  own  ship  are  fed 
into  the  DRA  from  Gyrocompass  and  pitometer-log  and  then  to 
the  DRT,  where  they  cause  a  movable  source  of  light  to  trace 
the  ship-track  continuously. 

In  all  systems  as  mentioned  above  the  target's  rela¬ 
tive  position  measurements  are  obtained  from  radar  repeater 
and  plotted  on  the  systems  which  are  read  to  be  used.  The 
range  measurement  accuracy  is  at  best  ±  20  yards  and 
bearing  measurement  accuracy  is  ±  1  degrees  with  a  well 
calibrated  repeater  and  a  well  trained  operator.  The  own 
ship  speed  and  course  are  used  to  determine  the  own  ship's 
velocity  vector.  The  course  and  speed  of  own  ship  may  vary 
±  1  degree  and  ±  1  knot  depending  on  the  helmsman,  weather 
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conditions  and  the  ship  instruction.  The  combined  result 
and  the  manual  solution  will  cause  ±  5  degrees  in  course 
and  ±  3  knots  in  speed  of  the  target  information.  Also 
the  major  disadvantage  of  the  manual  solution,  in  addition 
to  its  poor  accuracy,  is  the  time  required  to  obtain  the 
solution  and  the  inability  to  obtain  solutions  of  either 
the  target  or  own  ship  maneuvers  between  radar  position 
measurements,  typically  3  or  more  minutes  apart. 

C.  MICROPROCESSOR  TECHNOLOGY 

Recent  advances  in  large  scale  integration  (LSI)  semi¬ 
conductor  process  technology  have  made  possible  substantial 
reductions  in  the  cost  and  size  of  digital  logic  circuits. 
Microprocessors  represent  a  very  remarkable  achievement 
of  engineering  ingenuity  and  industrial  know-how  at  their 
best. 

Since  1973,  the  year  in  which  Intel  Corporation  shipped 
the  first  8080,  8-bit  N-channel  microprocessor,  a  number  of 
manufacturers  have  developed  similar  products  and  because 
of  this  competition  prices  have  been  drastically  lowered. 
With  hardware  and  software  system  development  costs  as  they 
are,  much  micro  work  is  done  on  a  custom  basis.  The  primary 
advantage  of  microcomputer  based  systems  is  to  have 
specialized  and  dedicated  equipment  solving  specific 
problems. 

The  microprocessor  families  are:  (1)  4-bit  machine; 

(2)  8-bit  machine;  (3)  16-bit  machine;  and  (4)  bit-slices 
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architecture.  16-bit  microprocessor  is  the  best  solution 
for  our  concern  of  tracking  problem.  But  Intel's  8080  was 
selected  as  an  8-bit  microprocessor  and  programmed  for 
double  precision  arithmetic  to  perform  Kalman  Filter 
algorithms,  because  of  its  lower  cost  and  availability  at 
the  Naval  Postgraduate  School  with  all  its  hardware  and 
software  support  devices. 

D .  SCENARIO 

In  order  for  a  ship  to  maintain  operational  readiness 
as  a  unit  of  a  task  force,  it  must  be  aware  of  the  current 
operational  environment.  The  operational  environment  is 
defined  as  the  surface/subsurface  contact  profiles  in  the 
geographic  area  of  interest.  The  contact  profile  consists 
of  friendly,  hostile,  and  unknown  contacts  with  associative 
contact  characteristics.  Contact  characteristics  are  such 
measurements  from  radar,  range  and  bearing  to  accurately 
determine  the  course  and  speed  of  a  radar  contact.  If  the 
radar  measurements  were  perfectly  accurate  and  the  target 
had  zero  acceleration,  then  the  tracking  problem  would  be 
velocity  vector  problem  as  shown  in  Figure  2,  velocity 
vector  and  contact  relative  motion  plot  as  shown  in  Figure  3. 
But  the  radar  bearing  and  range  measurements  on  any  scan  have 
errors  which  are  a  function  of  the  radar  system  and  the 
received  signal  to  noise  ratio.  The  measurement  errors  will 
be  discussed  after  defining  the  Kalman  Filter  parameters. 


Figure  3.  VELOCITY  VECTOR  AND  CONTACT  RELATIVE  MOTION  PLOT 
(Own  Ship  assumed  at  the  origin.) 
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The  contact  motion  on  a  X,Y  coordinate  system  can  be 
approximated  by  linear  dynamic  system.  The  target  dynamics 
can  be  represented  in  a  matrix  form  as  shown  below  to  define 


the  sample  data  system  such  as  a  search  radar  where  the 
measurements  are  taken  once  each  antenna  rotation 
(Reference  13) 
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Z  =  vehicle  state  vector  at  scan  n, 
n 

xn  *  E/W  position  of  the  vehicle, 

xn  =  E/W  velocity  of  the  vehicle, 

yn  =  N/S  position  of  the  vehicle, 

• 

yn  ■  N/S  velocity  of  the  vehicle, 

T  =  interval  between  observations, 

a  *  acceleration  acting  upon  the  vehicle  from 
scan  (n)  to  (n+1) . 


A  Kalman  filter  is  a  common  optimal  filtering  technique 
for  estimating  the  state  of  a  linear  system.  It  is  selected 
to  implement  the  tracking  problem  because  it  is  computa¬ 
tionally  the  most  demanding  technique  in  our  concern.  The 
details  of  the  Kalman  filter  will  be  analyzed  in  Chapter  IV. 


III.  SYSTEM  DESIGN  CONSIDERATIONS 


A.  HARDWARE  DESIGN  CONSIDERATIONS 

Microprocessors,  in  general,  are  not  complete  computers, 
but  Central  Processor  Units  (CPU)  implemented  with  one  to 
ten  large-scale  integrated-circuit  chips.  Large-scale 
integration  (LSI)  chips  are  comprised  of  1,000  or  more 
gates;  many  LSI  chips  hold  over  6,000  gates  or  a  "complete 
central  processor." 

The  word  "micro-computer"  refers  to  a  small  stored 
program  computer  comprising  memory  and  input/output  circuits 
together  with  a  microprocessor  CPU. 

Interface  design  a  nd  programming  make  the  mass-produced 
microcomputers  into  new  special-purpose  dedicated  machines. 

The  Intellec  Microcomputer  Development  System  (MDS)  is 
a  complete,  coordinated  computer  system  designed  around 
Intel's  8080  microprocessor.  The  MDS  has  a  2  microsecond 
instruction  cycle,  a  repertoire  of  72  powerful  instructions, 
unlimited  subroutine  nesting,  and  a  versatile  interrupt 
scheme . 

The  MDS  was  selected  because  of  its  8080  microprocessor, 
its  memory  capabilities,  its  interrupt  mechanism,  and  its 
extended  I/O  capabilities.  Also,  the  selection  of  the 
Intel  Microcomputer  Development  System  (MDS)  was  made  for 
this  theis  because  of  its  immediate  availability  at  the 
Naval  Postgraduate  School. 
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A  Datamedia  Elite  2500  Video  Terminal  was  chosen  to 
present  alphanumeric  information  because  its  features 
includes  (1)  Editing  and  roll  operation  modes;  (2)  50  to 
3600  baud  programmable  speed  transmission;  (3)  protected 
fields,  (4)  computer  derived  or  high  light  field  (blink) ; 

(5)  addressable  cursor. 

Because  of  the  computation  of  Kalman  filter  algorithms, 
floating-point  calculation  required,  an  SBC- 310  high-speed 
math  unit,  developed  by  Intel  Corporation,  was  incorporated. 

In  performing  high  speed  mathematical  functions,  the  Math 
Unit  acts  as  an  intelligent  processor,  performing  a  reper¬ 
toire  of  14  arithmetic  functions  and  at  least  an  Oder  of 
magnitude  faster  than  comparable  software  routines.  Why 
it  is  to  selected  to  perform  the  algorithms  will  be  discussed 
in  Section  C  of  this  Chapter,  and  Figure  4  shows  the  final 
configuration  of  the  equipment  used  in  developing  this 
thesis.  Also,  start-up  procedures  for  the  system  were  listed 
in  Appendix  B. 

B.  SOFTWARE  DESIGN  CONSIDERATIONS 
1.  Language  Selection 

Choice  of  the  computer  language  to  be  used  was 
partially  dependent  upon  the  hardware  configuration. 

PL/M-80  was  preferred  as  a  programming  language  to  be  used, 
after  selecting  MDS  hardware  system,  to  the  assembly  language 
because  of  its  ease  as  programming  and  immediate  availability. 

PL/M-80  is  a  high  level  language  developed  by  Intel 
Corporation  and  esigned  especially  for  system  and  applications 
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Figure  4.  EQUIPMENT  CONFIGURATION 

programming  for  the  Intel  8080  microprocessor.  It  is  a 
block  structured  language  which  speelds  the  microprocessor 
program  development  by  relieving  the  programmer  of  the 
tedious  task  of  memory  and  register  management. 

ISIS-II  disk  operating  system  also  developed  by  Intel 


Corporation  for  the  Intellec  MDS  system  has  a  resident 
PL/M-80  compiler  which  has  been  very  useful  during  the 


implementation,  debugging  and  testing  the  program.  The 
PL/M-80  compiler  accepts  the  statements  as  input  and  produces 
a  machine-code  program  module  as  output. 

PL/M  statements  are  divided  into  two  basic  categories: 

1.  DECLARE  and  PROCEDURE  statements. 

2.  EXECUTABLE  statements,  which  are  all  other  than  declare 
and  procedure  statements. 

EXECUTABLE  statements  cause  machine  code  to  be  generated. 
DECLARE  statements  cause  variables  to  be  defined  associated 
with  objects  and  PROCEDURE  capability  permits  program  to 
be  constructed  in  a  modular  fashion,  which  has  numerous 
advantages  including  efficiency  of  coding,  readability  of 
programs,  ease  of  debugging  and  possibility  of  using  the 
same  procedure  in  more  than  one  program  (Ref.  6). 

2.  Floating  Point  Arithmetic 

Floating  point  arithmetic  is  required  because  range 
of  numbers  to  be  represented  is  large  and  sometimes  unpre¬ 
dictable,  especially  in  the  Kalman  filter  algorithm.  In 
this  algorithm  when  the  time  concern  to  use  a  floating  point 
arithmetic  is  disadvantageous,  because  it  needs  additional 
subroutines  or  hardware,  but  when  the  accuracy  concern  we 
must  use  it  in  our  programming . 

In  selecting  floating-point  formats,  the  primary 
considerations  are  word  size  and  the  radix  of  the  arithmetic. 
In  much  of  the  literature,  24-bit  word  size  is  regarded  as 
too  small  for  scientific  computation.  The  Intel  standard 
for  floating  point  arithmetic  has  been  adopted  to  apply  to 
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all  general  purpose  products  including  software  systems, 
and  components.  Such  as  FPAL  (Floating-Point  arithmetic 
library)  for  the  8080  and  Math  Board  (SBC-310)  made  of  series 
3000  bit  slices  have  already  been  produced  using  this 
standard. 

As  the  floating-point  arithmetic  formats  concern 
there  are  two  standard  formats  which  have  been  accepted 
from  Intel  (Ref.  12):  (a)  32-bit  short  precision  word; 

(b)  62-bit  long  precision  word.  The  32-bit  short  precision 
word  format  with  binary  radix  was  chosen  because  of  the  hard¬ 
ware  consideration  by  selectin  the  MDS  system  and  8080 
microprocessor  with  SBC-310  high  speed  mathematics  unit  was 
the  fastest  and  available  at  the  Naval  Postgraduate  School. 

Comparison  will  be  done  next  with  its  compatibles: 

(1)  AM9511  Arithmetic  processing  unit  (Advanced 
Micro  Devices,  Inc.) 

(2)  8080/8085  Floating-Point  Arithmetic  Library  (FPAL) 
(Intel  Corporation) 

(3)  24-bit  special  floating  point  (Ref.  11) 

(4)  SBC  310  High  Speed  Mathematic  Unit  (Intel 
Corporation) . 

a.  AM9511  Arithmetic  Processing  Unit 

The  AM9511  is  a  monolithic  MOS/LSI  device  which 
provides  high  speed,  16  and  32  bit  fixed  and  32  bit  floating¬ 
point  arithmetic,  plus  a  group  of  transcendental  derived 
functions,  control  and  conversion  commands. 

The  AM9511  APU  is  contained  within  a  single 
dual-in-line  24  pin  chip  as  described  in  detail  in  Ref.  3. 
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The  distinctive  characteristics  of  the  AM9511 

APU  include: 

-  Fixed-point  16  and  32  bit  operation 

-  Floating-point  32  bit  operation 

-  Binary  data  formats 

-  Basic  add,  subtract,  multiply  and  divide 

-  Trigonometric  sine,  cosine,  tangent 

Inverse  trigonometric  arcsine,  arccosine,  arctangent 

-  Square  roots 

-  Logarithms  base  on  10  and  e 

-  Exponentiation 

-  Float-to-f ixed  and  fixed-to- float  conversions 
stack  oriented  operand  storage 

-  DMA  or  programmed  I/O  data  transfers 

-  General  purpose  8-bit  data  interface. 

Data  Formats: 

All  fixed-point  operands  and  results  are 
represented  as  binary  two's  complement  integer  values.  The 
16  bit  format  can  express  numbers  with  a  range  of  -32,768 
to  +32,767.  The  32  bit  format  can  express  numbers  with  a 
range  of  -2,147,483,648  to  +2,147,483,647. 

The  floating  point  format  uses  a  32  bit  word 
width  as  shown  in  Figure  5.  The  most  significant  bit  (bit  31) 
indicates  the  sign  of  mantissa.  The  next  seven  bits  form 
the  exponent  and  remaining  24  bits  form  the  mantissa  value. 
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Figure  5.  FLOATING-POINT  FORMAT  FOR  AM9511  APU 

The  exponent  of  the  base  2  is  an  unbiased  two's 
complement  number  with  a  range- of  -64  to  +63.  The  mantissa 
is  a  sign-magnitude  number  with  an  assumed  binary  point 
just  to  the  left  of  the  most  significant  mantissa  bit  (bit  2) . 
All  floating  point  values  must  be  normalized  which  makes 
bit  23  always  equal  to  1  except  when  representing  a  value  of 
zero.  The  number  zero  is  represented  with  binary  zeros  in 
all  32  bit  positions. 

The  operation  of  the  APU  is  described  in  Ref.  3 
in  detail  with  the  command  formats  and  their  descriptions. 

The  AM9511  interested  commands,  its  clock  cycles  and 
typical  execution  times  for  three  different  clock  frequencies 
such  as  2  MHz,  3  MHz  and  4  MHz  are  shown  in  Table  I. 
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COWAND 

JtttKWIC 


CLOCK  CYCLES 


AM9511 
(2  MHz) 


AM95I1-1 
(3  mz) 


AM9511-4 
(4  MHz) 


i 


1  32-BIT  FIXED  POINT  OPERATIONS 

ADD 

(DADD) 

22-22 

10 

7 

5 

SUBTRACT 

(DSUB) 

38-40 

19 

13 

10 

MJLTIPLY,  LOWER 
(OMUL) 

184-210 

97 

65 

49 

MULTIPLY,  UPPER 
(EMUU) 

182-218 

91 

61 

46 

DIVIDE 

(DDIV) 

186-210 

98 

66 

50 

1  32-BIT  FIOATING-POINT  PRIMARY  OPERATIONS 

ADD 

(FADD) 

54-368 

27 

18 

14 

SUBTRACT 

(FSUB) 

70-370 

35 

24 

18 

MULTIPLY 

(EMIL) 

146-168 

73 

49 

37 

DIVIDE 

(FDIV) 

154-184 

77 

52 

38 

|  32-BIT  FLOATING-POINT  DERIVED  OPERATIONS 

squareroot 

(SOFT) 

782-870 

391 

262 

200 

LOG  BASE  10 
(LOG) 

4474-7132 

2237 

1493 

1125 

LOG  BASE  e 
(IX) 

4298-6956 

2149 

1435 

1098 

dote:  All  time  values  are  specified  in  microseconds. 

Table  I.  AM9511  ARITHMETIC  PROCESSING  UNIT  COMMAND 
EXECUTION  TIMES 


TXPICAL  EXECUTION 


TIMES 


GQMAND 

MNEMONIC 

CLOCK  CYCLES 

AM9511 
(2  mz) 

AM9511-1 
(3  mz) 

AM95U-4 
(4  mz) 

N  OF  32-BIT  FLQATIMG-POIOT  DERIVED  OPERATE 

DNS 

SINE 

(SIN) 

3786-4808 

1898 

1266 

950 

COSINE 

(OOS) 

3840-4878 

1920 

1280 

960 

TANGENT 

(TAN) 

4894-5886 

2447 

1635 

1225 

ARCSINE 

(ASIN) 

6230-7938 

3115 

2080 

1560 

ARCCOSINE 

(AOOS) 

6304-8284 

3152 

2105 

1580 

ARCTANGENT 

(MAN) 

4992-6536 

2496 

1665 

1250 

EXPONENT 

(EXP) 

3784-4878 

1887 

1265 

949 

POWER 

(PWR) 

8280-12032 

4145 

_ _ 

2765 

2075 

|  32-BIT  DATA  AND  STACK  MANIPULATION  OPERATIONS 

FIXED-TO-FDOAT 

CONVERSION 

(flu)) 

56-342 

28 

19 

14 

FD3AT-TO-FIXED 

CONVERSION 

(FXTD) 

20-336 

45 

30 

23 

mm 

16-20 

8 

6 

4 

EXCHANGE 

(XCHF) 

26 

13 

9 

7 

Note:  All  tine  values  are  specified  in  microseconds. 


Table  1  (Continuation) .  AM9511  ARITHMETIC  PROCESSING 

UNIT  COMMAND  EXECUTION  TIMES 
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b.  8080/8085  Floating-Point  Arithmetic  Library  (FPAL) 
The  FPAL  procedures  reside  in  object  code  module 
form  in  the  library  "FPAL. LIB"  on  the  Intellec  ISIS-II 
System  diskette.  They  are  self  contained  and  can  be  used 
in  component,  OEM-board,  or  Intellec  Microcomputer,  Develop¬ 
ment  System.  It  contains  basic  floating  point  subroutines 
and  functions  (referred  to  generally  as  "procedures") . 

The  operations  provided  ares 

-  Addition,  subtraction,  multiplication,  division 

-  Value  comparison 

-  Conversion  between  decimal  and  binary  floating  point 
and  32  bit  signed  integer  formats 

-  A  default  error  handler  subroutine. 

For  all  operations  single  precision  format  is  used  and  in 
addition  to  these  operations,  a  number  of  procedures  are 
provided  to  deal  with  the  Floating  Point  Record  (FPR) .  This 
is  a  reserved,  18  byte  work  area  used  to  collect  status  and 
error  information,  and  as  an  accumulator  for  intermediate 
results.  The  procedures  supporting  the  FPR  perform  FPR 
initialization,  change  error  recovery  options,  check  the 
contents  of  FPR  fields,  and  pass  numbers  between  the  FPR 
and  memory. 

The  FPAL  also  includes  a  default  error-handler 

i 

subroutine.  This  subroutine  is  called  when  an  invalid  number 
is  used  in  a  floating-point  operation  or  if  overflow, 
underflow,  or  division  by  zero  are  not  handled  by  an 
arithmetic  subroutine.  We  may  also  write  our  own  error 
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handler,  so  long  as  it  conforms  to  the  formats  described 
in  Reference  2. 

The  FPAL  can  be  used  by  assembly  langugages  or 
PL/M  programs. 

In  general,  the  following  steps  must  be  observed 
to  use  the  Floating-Point  Library: 

1)  An  area  of  memory  must  be  reserved  for  the  Floating- 
Point  Record  (FPR) . 

(2)  The  names  of  the  FPAL  procedures  must  be  declared  to 
be  "external". 

(3)  FPAL  procedure  references  must  be  imbedded  in  our 
source  code  where  appropriate. 

(4)  The  FPAL  procedure  used  by  our  program  must  be  linked 
to  our  object  file. 

(5)  If  we  want  to  use  the  FPAL  procedures  in  our  program, 
that  program  cannot  use  symbols  that  are  reserved  for 
FPAL  such  as  symbolic  names  beginning  with  a 
"commercial  at"  sign,  or  names  whose  second 
character  is  "Q"  or  "?". 

Floating  Point  Record  (FPR)  procedures, 
arithmetic  procedures,  error  handling  procedures,  and  inter¬ 
face  to  FPAL  are  described  in  Reference  2  in  detail. 

Data  Formats? 

FPAL  procedures  operate  on  single-precision 
binary  numbers,  either  32-bit  integer  format  or  in  a  32-bit 
floating-point  format. 


The  integer  format  recognized  by  the  FPAL  is  a 


positive  or  negative  (two's  complement)  32-bit  binary  number 
The  approximate  range  of  this  format  is  from  -2. 14 7x1 09  to 

q 

+2.147x10  .  Single-precision  formats  in  the  floating-point 


where  s  =*  sign  bit 
e  =*  exponent 

f  =  fraction  or  mantissa 


Figure  6.  SINGLE  PRECISION  FORMAT  FOR  FPAL 

The  three  fields  within  these  formats  ares 

s . is  the  sign  bit.  Sign  magnitude  repre¬ 

sentation  wehre  s  =  0  means  positive  and 
s  *  1  means  negative. 

e . is  exponent  bits.  The  exponent  is  offset  by 

7 

(2  -1) .  All  zeros  and  all  ones  in  the 
exponent  field  are  currently  reserved  for  the 
floating  point  zero  and  the  invalid  numbers 
described  above. 


£ . is  fraction  bits.  When  the  exponent  is  nonzero, 

a  1  bit  is  assumed  at  the  left  of  the  fraction; 
the  binary  point  is  between  the  assumed  bit 
and  the  explicit  fraction  bit. 

The  number  base  for  the  FPAL  is  binary.  The 
value  of  a  given  binary  representation  can  be  formulated  as 

(-1) S  2e“(27”1) . (1.  +  .f) 

where  e  ^  0  and  e  /  FF. 

When  overflow  or  underflow  occurs  during  FPAL 
operations,  the  correct  fraction  results  but  the  exponent 
is  "wrapped  around".  A  "wrapped  around"  exponent  is  defined 
to  be  ew,  where  the  true  (offset)  exponent,  efc,  can  be 
derived  from  ew  by  considering ' an  expanded  range  of 
exponents  and 

on  overflow  efc  =  ew  ”  (3.26-2) 

on  underflow  e.  =  e.  -  (3.26-2)  . 

t  w 

The  floating  point  arithmetic  library  (FPAL)  complete 
functions  and  execution  times  are  given  in  Table  2. 
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FPAL  Procedure 


’loat. -Point  Add.  (FAED) 


'loat. -Point  Subtract  (FSUB) 


’loat. -Point  Multiply  (FMUL) 


'loat. -Point  Divide  (FDIV) 


onversion  fran  binary  float. -point 
unber  to  decimal  (PQFT32D) 


loat-to-Fixed  Conversion  (FIXSD) 


ixed-to-Float  Conversion  (FLTDS) 


loating  Point  Oonpare  (FCMPR) 


looting  Pint  Test  (FZTST) 


'loating  Point  Absolute  (FABS) 


loating  Point  Negative  (FNEG) 


Note:  All  time  values  are  specified  in 
microseconds . 


Table  2.  8080/8085  FPAL  FUNCTIONS  AND  EXECUTION 

TIMES 


Bytes 

Typical 

Execution 

Time 

463 

700 

463 

700 

404 

1500 

342 

3600 

725 

not  given 

1585 

not  given 

178 

not  given 

139 

not  given 

159 

300 

56 

not  given 

36 

not  given 

43 

rot  given 
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c.  24-Bit  Special  Floating-Point  Arithmetic 

Software  Subroutines 

This  software  subroutine  has  been  written  in 
Reference  11  to  perform  the  floating-point  arithmetic.  But 
the  format  that  has  been  used  is  not  our  concern  and  not 
suitable  to  our  standards.  The  only  reason  it  was  mentioned 
here  is  to  show  how  slow  execution  times  it  has  even  with 
16-bit  mantissa.  Its  functions  and  execution  times  are 
given  in  Table  3. 

d.  The  SBC  310  High-Speed  Mathematics  Unit 

The  SBC  310  High-Speed  Mathematics  Unit  is  a 
member  of  a  complete  line  of  Intel  SBC  80  system  expansion 
modules.  In  performing  high-speed  mathematic  functions, 
the  Math  Unit  acts  as  an  intelligent  processor  slaved  to 
one  or  more  SBC  80  computer  masters.  The  math  unit  performs 
its  repertoire  of  14  arithmetic  functions  an  order  of 
magnitude  faster  than  is  possible  with  software  routines. 

Its  functions  and  execution  times  are  shown 
in  Table  4  and  a  detailed  description  of  programming  infor¬ 
mation  and  principles  of  operation  are  explained  in 
Appendix  A  because  it  was  selected  to  perform  this  thesis. 

Four  different  systems  and  their  features  have 
been  explained  individually  as  they're  chosen  to  be 
compared  in  the  beginning  of  this  section.  The  comparison 
among  the  SBC  310,  High-Speed  Math  Unit,  the  AM9511 
Arithmetic  Processing  Unit,  the  Floating-Point  Arithmetic 
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OPERATION  NAME 


MAX  EXECUTION  TIME 


24-Bit  Floating-Point  Addition 
(ADD) 

1300 

24-Bit  Floating-Point  Subtraction 
(SUB) 

1400 

24-Bit  Floating-Point 

Multiplication 

(MULT) 

3400 

24-Bit  Floating-Point  Division 
(DIV) 

4100 

24-Bit  Floating-Point  Comparison 
(COMPARE) 

800 

24-Bit  Floating-Point  Squareroot 
(SQRT) 

17,000 

24-Bit  Floating-Point  Cosine 
(TRIG  1) 

18,000 

24-Bit  Floating-Point  Sine 
(TRIG  2) 

1*000 

24-Bit  Floating-Point  Cos  and  Sine 
(TRIG  3) 

3*000 

24-Bit  Floating-Point  Arctangent 
(TRIG  4) 

1*000 

Note:  All  time  values  are  specified  in  microseconds. 

Table  3.  24-BIT  SPECIAL  FLOATING-POINT  ARITHMETIC 
OPERATIONS  NAME  AND  EXECUTION  TIMES 


OPERATION  name 


CODE 


Fixed-Point  Multiply  (MUL) 


Fixed-ftjint  Divide  (DIV) 


Extended  Fixed  Point  Div.  (EDIV) 


Float. -Point  Multiply  (FMUL) 


Float. -Point  Divide  (FDIV) 


Float .  -Point  Add  (FAED) 


Float. -Point  Subtract  (FSUB) 


Float. -Point  Square  (FSQR) 


Float. -Point  Square  Root  (FSGpT) 


Fixed-fco-Float.  Conversion  (FLTDS 


Float. -to-Fixed  Conversion  (FIXED 


Float.  Point  Ocnpare  (FCMPR) 


Float.  Point  Test  (FZTST) 


Exchange  (EXCH) 


Dte:  All  time  values  are  specified  in  microseconds . 

Listed  times  do  not  include  time  to  pass  arguments  to  the 
MATH  UNIT  and  to  read  results  upon  completion;  this  is 
typically  20  microseconds. 


TYPICAL 

BCECUTION 

TIME 

15 

20 

26 

30 

84 

100 

84 

100 

92 

110 

33 

75 

33 

75 

84 

100 

178 

205 

72 

100 

42 

85 

Table  4.  SBC-310  HIGH  SPEED  MATH  UNIT  FUNCTIONS  AND 

EXECUTION  TIMES 


Library  (FPAL) ,  and  2 4 -bit  Special  Floating-Point  Software 
execution  times  of  their  operations  are  shown  in  Table  5. 

The  AM9511  APU  has  the  fastest  and  SBC-310  High 
Speed  Math  Unit  has  the  second  fastest  execution  times. 
Also,  if  we  compare  the  cost  of  the  units,  the  AM9511  is 
only  $195  in  the  market  and  it  is  cheaper  than  SBC-310 
Math  Unit.  But,  when  the  purpose  of  this  thesis  concern, 
as  a  Kalman  Filter,  and  immediate  availability  at  the 
Naval  Postgraduate  School,  the  SBC  310  High-Speed  Math  Unit 
was  chosen  to  perform  the  arithmetics  of  the  Surface/ 
Subsurface  Bearing-Only  Tracking  Radar  algorithms. 

C.  PHILOSOPHY  OF  SOFTWARE  DESIGN 

The  system  was  designed  with  the  following  objectives: 

1)  Human  engineered  user  interface. 

2)  Capability  of  solving  maneuvering  board  problems 
using  Kalman  Filter  algorithms. 

3)  Capability  to  display  the  result  and  the  error 
performance  of  the  assumed  problem  definition. 

In  order  to  avhieve  these  objectives,  the  following 
modules  were  developed: 

a)  "INT$DATA":  This  module  contains  range  and  bearing 
information  of  selected  contacts  and  their  observation  time 
intervals  for  each  scan. 

b.  "MAIN$PROG":  This  module  is  used  to  perform  the 
implementation  of  Kalman  filter  algorithms,  results  and 
error  calculations. 
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SYSTEM 

NAMES 


TYPICAL 


OtJ  TIMES 


OPERATION 


EMIL 


DIV 


SBC  310  AM9511  FmL 

High  Speed  Arithmetic 
Math  Unit  Proc.  Unit  ^tcwareJ 


32-bit  Fixed  Point  Operations 


97 


32-bit  Floating  Point  Operations 


EMJL 

84 

73 

1500 

3400 

FDIV 

92 

77 

3600 

4100 

EADD 

33 

27 

700 

1300 

FSUB 

33 

35 

700 

1400 

FSQR 


FSQRT 


Fixed-to-Float 

Conversion 


'•'il 


17,000 


Float-to-Fixed 


FCBMPR 


SINE 


OOSIEE 


AFCTG 


Note:  All  time  values  are  specified  in  microseconds. 


800 


18,000 


18,000 


30,000 


Table  5.  COMPARISON  OF  FOUR  DIFFERENT  SYSTEMS  EXECUTION 
TIME  OF  OPERATION 


c.  "DISPLAY":  This  is  used  to  display  the  result 
and  error  calculations  on  the  CRT. 

d.  "FLOATING$POINT" :  This  module  is  used  to  perform 
all  the  necessary  floating-point  operations  and  to  calculate 
the  cosine  and/or  sine  of  a  given  angle  in  radians  and  the 
arctangent  of  the  ratio  of  two  input  parameters. 

The  whole  program  is  listed  in  Appendix  E.  The  formats, 
units  and  conversion  factors  used  in  the  program  are  shown 
in  Table  6.  The  Kalman  filter  will  be  described  in 


Chapter  IV. 


FORMAT 


UNITS 


I/O 

INTERNAL 

I/O 

INTERNAL 

TIME 

XXXX . XX 

F.P. 

seconds 

same 

COURSE 

XXXX . XX 

F.P. 

degrees 

radians 

SPEED 

XXXX. XX 

F.P. 

n.mile/ 

sec. 

BEARING 

XXXX. XX 

F.P. 

degrees 

radians 

RANGE 

XXXX. XX 

F.P. 

yards 

nautical 

miles 

x .  Numeric  Character 

F.P.. . Floating  Point  Representation 


x .  Numeric  Character 

F.P.. . Floating  Point  Representation 


1  nautical  mile .  2025.3716  yards,, 

1  degree  .  0.0174532925  radians 

1  knot  .  1  nautical  mile/hour 

ir  .  3.141593 


Table  6.  FORMAT,  UNIT  AND  CONVERSION  FACTORS  USED 
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IV.  KALMAN  FILTER 


A  two  dimensional  Kalman  tracking  filter  provides  a 
convenient  framework  for  determining  optimal  filter 
parameters  for  x,y  tracking  for  a  two-dimensional  radar 
measuring  range  R  and  bearing  e. 

A.  DISCRETE  KALMAN  FILTER  ALGORITHM 

The  vehicle  dynamics  can  be  represented  in  matrix  form 
as  stated  earlier. 


Z  ..  *  «  +  r  a„  (Ref.  13) 

n+i  n  n 

where  ZR,  r  and  an  were  defined  in  Chapter  II. 

The  discrete  form  of  a  Kalman  filter  rather  than 
continuous  form  is  appropriate  because  of  surface  search 
radar  antenna  rotation  results  in  scan  while  measurements 
of  the  contact  position.  The  matrix  form  of  the  observation 
equation  can  be  written  as 
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(Ref.  13) 


where 


w 


n 


x  (n) 
m 

y_(n) 

m 


42 


x  (n)  =  measured  x  coordinate  at  scan  n 
m 

y  (n)  =  measured  y  coordinate  at  scan  n 

J  TO 


H 


10  0  0 
0  0  10 


Z  =  Vehicle  state  vector  at  scan  n 
n 


Vn> 

vy(n) 


vx(n> 

vy(n) 


-  random  noise  on  x  measurement  at  scan  n,  xm(n) 

=  random  noise  on  y  measurement  at  scan  n,  ym(n). 


Optimal  estimates  of  the  contact  state  vector  at 
scan  n,  Zn  are  given  by 

Z  *  Z  +  K  (w  -  HZ  )  (Reference  13) 

n  n  n  n  n 

where 

Z  is  the  estimated  state  vector  at  scan  n. 
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4  (see  Chapter  II,  Section  D) 


Zn_^  *  Optimal  estimate  of  target  state  vector  at  scan  (n-1) 

and 
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Zn  is  the  optimum  estimate  of  the  state  vector  after  the 
measurement  wr  is  processed 

Zn  is  the  optimum  estimate  of  the  state  vector  before 
the  measurement  wn  is  processed 

Kn  =  PnHT(HPrHT  +  Rn)_1  (Reference  13) 


Kn  is  the  gain  matrix  at  scan  n  and  computed  for  steady- 
state  as 
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P  is  the  estimated  covariance  matrix  of  the  estimation 
n 

errors  prior  to  the  processing  run. 

R  is  the  covariance  matrix  for  the  observation  noise, 
n 


<■*<”>  °xy<n) 

‘’xy'1'1  °y(n) 

where  using  the  polar  coordinate  system  shown  in  Figure  7 


(WEST) 


x  =  R  sin  6 
m 

y  =  R  cos  e 

HI 


(EASl 


Figure  7.  COORDINATE  SYSTEM 


The  elements  of  the  covariance  matrix  for  observation 
noise  are: 

a  2(n)  *  o  2  sin2  0  +  R2  (n)  cos2  0  (n)  o  2 

x  jl  _  y 

o  2(n)  =  a  2  cos2  6 (n)  +  R2  (n)  sin2  0 (n)  o  2 

y-  r  6 

axy(n)  =  ^  sin  20(n)[ar2  -  R2 (n)  aQ2] 

2 

ar  *  variance  of  the  range  measurement  noise 
2 

o  “  *  variance  of  the  bearing  measurement. 

0 

R(n)  and  e (n)  are  the  vehicle  range  and  bearing  at  scan  n. 
The  covariance  matrix  Pn  can  be  computed  recursively  as 

Pn+^  =  <J>  Pn  «T  +  rQrT  (Reference  13) 

with  P„  =  (I  -  K  H)  P„ 
n  n  n 

* 

where  P  is  the  covariance  matrix  of  estimation  error 
n 

after  processing  wR. 

2 

Q  *  o  and  it  is  the  variance  of  random  contact 

d 

acceleration.  The  variance  of  contact  acceleration  must 
be  equal  and  independent  along  x  and  y  axis,  and  from  scan 
to  scan. 
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This  form  of  the  Discrete  Kalman  filter  is  valid  for 
our  contact  maneuver  problem.  But  the  solution  of  the 
equations  in  matrix  form  is  unnecessarily  complex  for  the 
microcomputer.  Therefore,  an  algebraic  solution  of  each 
element  in  the  matrix  form  of  equations  was  formulated. 

These  equations  are  listed  in  Appendix  D. 

B.  KALMAN  FILTER  PARAMETERS 

The  Kalman  Filter  performance  is  determined  by  three 

parameters: 

2 

1)  o„  -  Variance  of  the  range  measurement  error 

2 

2)  oQ  -  Variance  of  the  bearing  measurement  error 

2 

3)  a  -  Variance  of  the  contact  acceleration. 

St 

The  first  two  parameters  are  functions  of  the  selected  radar 
and  the  ship's  gyrocompass.  The  third  parameter  is  a 
function  of  the  contact  relative  motion  and  the  desired 
smoothness  of  the  output  data. 

In  order  to  solve  the  tracking  problem  and  figure  out 
the  parameters  of  the  Discrete  Kalman  Filter,  it  is  necessary 
to  make  measurements  of 

a.  Contact  Range, 

b.  Contact  Bearing, 

c.  Own  Ship's  Course, 

d.  Own  Ship's  Speed,  and 

e.  Time  of  the  observation. 
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It  is  assumed  that  all  noise  is  Gaussian  and  Received 
signal  to  noise  ratios  are  large  (>>1) . 

The  minimum  performance  of  the  selected  radar  (AN/SPS-10) 
characteristics  are  listed  in  Appendix  C  and  the  video 
signal  to  noise  ratio  with  single  pulse  detection  is  given 
as 


S 
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G2  X2  a  10“aR/5 


pk  _ 

(4ir)  ^kT  F  B  L  R4 


o  n  n  s 


where 


(Reference  8) 


*  peak  transmitted  power  (Watts) 

G  =  antenna  gain 

X  »  wavelength  (m) 

2 

a  *  radar  cross  section  of  contact  (m  ) 

at  =  attenuation  constant  of  propagation  medium  (dB/m) 

R  a  range  to  contact  (m) 

-23 

k  *  Boltzman's  constant  (1.23x10  joule/deg) 

Tq  «  standard  temperature  (280°K) 

B„  *  receiver  noise  bandwidth  (Hz) 

n 

Lg  *  system  losses. 

The  contact  range  is  determined  by  measuring  the  time 
required  for  a  radar  pulse  to  travel  to  and  from  the  contact. 
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where  c  =  speed  of  light 

t  =*  elapsed  time  from  pulse  transmission  to 
pulse  detection 
R  =  range  to  contact. 

Threshold  detection  could  be  used  to  indicate  the 
occurrence  of  the  leading  edge  of  the  received  radar  video 
pulse.  Leading  edge  detection  is  selected  because  it 
eliminates  errors  resulting  from  variations  in  the  pulse 
width.  The  standard  deviation  of  range  error  is  given 
below  if  the  rise  time  of  the  pulse  is  limited  by  receiver 
bandwidth  B. 
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2B(J  |) 


(Reference  8) 


The  contact  bearing  is  determined  by  measuring  the 
bearing  of  the  radar  beam  at  the  time  the  contact  video 
is  detected.  Using  beam  splitting  technique  to  estimate 
the  center  bearing  of  the  contact,  the  standard  deviation 
of  bearing  error  is 


1.060, 


T7T 


«"g  ‘t’c1 


where 


a.  ■  standard  deviation  of  bearing  error 

e  *  two  way  beamwidth 
9 

e 

(«)  »  signal  to  noise  ratio  at  center  of  beam 

n  c 

Ng  *  number  of  pulses  emitted  as  the  antenna  rotates 


The  standard  deviation  of  range  error  and  bearing  error 
are  functions  of  the  video  signal  to  noise  ratio  that  is 
given  on  page  48  for  a  single  pulse  detection.  When 
considering  the  threshold  to  noise  ratio,  it  is  necessary 
to  define  both  the  desired  mean  time  between  false  alarms 
and  minimum  probability  of  detection  of  the  contact. 
Probability  of  false  alarms  is  given  by  Ref.  8'  in  terms  of 
the  mean  time  between  false  alarms  and  the  IF  bandwidth  of 
the  receiver  as  shown  below. 
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FA 


1 

T  B 
aFA  IF 


The  mean  time  between  false  alarms  is  a  function  of 
the  threshold  to  noise  power  ratio  and  the  receiver  IF 
bandwidth.  And  it  can  be  increased  if  the  tracking  system 
is  off  whenever  the  contact  is  not  in  our  selected  range. 
The  maximum  unambiguous  range  of  AN/SPS-10  Radar  is  129.6 
nautical  miles  and  for  example  50  nm  of  that  is  of  our 


concern.  This  would  disable  the  measurement  circuitry 
61.4  percent  of  the  time  and  it  will  give  us  an  additional 
advanatage . 

The  mean  time  between  false  alarms  of  35.3  sec  (10  times 

the  mean  interval)  has  been  selected.  The  probability  of 

—  9  —8 

false  alarms  5.66x10  for  one  contact  and  1.93x10  for 

50  nm  of  our  interest  range.  And  this  leads  to  a  threshold 

to  noise  power  ratio  of  12.5  dB.  Also  the  reflected  radar 

signals  from  contact  will  fluctuate  due  to  cancellation 

and  reinforcement  of  the  waves  reflected  from  'various 

positions  of  the  contact.  These  fluctuations  can  be  formed 

as  Swerling's  Case  1  and  additional  11  to  14  dB  will  be 

required  to  insure  a  probability  of  0.9  to  0.99  resepectively . 

The  standard  deviation  for  bearing  and  range  can  be 
related  to  contact  range  and  cross  sectional  area  as  given 
in  Ref.  9.  Based  on  a  threshold  to  noise  ratio  of  12.5  dB 
and  interested  range  of  a  50  nm  the  standard  deviation 
of  the  radar  range  and  bearing  errors  will  be  140.2  yards 
and  0.2062  (0.003599  rad),  respectively. 

In  addition  to  radar  measurement  errors  also  there  are 
ship's  gyrocompass  and  pitometer  log  errors  which  come  from 
the  own  ship's  course  and  speed  measurements.  And  gyro¬ 
compass  not  only  determines  own  ship  course  but  also  deter¬ 
mines  the  true  bearing  of  the  radar  antenna.  It  is  assumed 
that  the  standard  deviation  of  own  ship's  gyrocompass 
error  is  0.1  degrees  (0.001745  rad)  and  standard  deviation 
of  own  ship's  pitometer  log  error  is  0.1  knots. 
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Therefore,  the  variance  of  bearing  error  is  equal  to 

2 

the  sum  of  the  radar  bearing  error  (0.0425  deg  ),  and  the 

2 

variance  of  the  own  ship's  gyrocompass  error  (0.01  deg  ) 

2 

leads  to  the  total  variance  of  bearing  error  0.0525  deg 
—  6  2 

or  15.998x10  rad  .  The  variance  of  range  error  is 
2 

0.0048  nm  . 

The  variance  of  target  acceleration  parameter  is  the 
ability  of  the  filter  to  provide  the  closest  estimate  of 
a  contact's  position  and  velocity  for  a  moving  contact. 

It  is  good  to  allow  the  experienced  operator  to  choose  the 
variance  of  acceleration  parameter  to  be  used  with  each 
contact. 

C.  KALMAN  FILTER  INITIAL  CONDITIONS 

As  it  is  explained  before  the  Kalman  Filter  algorithms 
represent  the  recursive  calculations  of  the  optimal 
estimates  of  the  covariance  of  estimation  error  matrix  and 
the  contact  state  matrix.  The  initial  condition  of  the 
contact  state  matrix  is  equal  to  the  expected  value  of  the 
initial  state.  The  expected  values  of  the  initial  position 
elements  are  the  first  measurements: 

XQ  =  R(0)  sin  6(0) 

Yq  *  R(0)  cos  0 (0) 

The  expected  values  of  the  initial  velocity  elements  are 


The  initial  condition  of  the  covariance  of  estimation 


error  matrix  is  equal  to  the  covariance  of  error  of  the 
initial  state  estimate: 


P  (0)  =  E  [Z 0  -  Z  (0)  3  tZ  (0)  -  Z  (0)  ] 


El(Xo-X0>2  0 
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E[(Yq-Y0)  ] 


0 

0 

0 


E[Y0)  1 


The  time  required  for  the  Kalman  Filter  to  achieve 
a  steady-state  condition  is  very  sensitive  choosing  the 
closest  right  values  of  the  nonzero  elements  of  the  initial 
state  estimate  matrix.  They  were  chosen  to  be  brought  the 
contact  on  y-axis  as  an  initially  by  given  equations  in 
Reference  13. 
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V.  SYSTEM  DESCRIPTION 


The  description  of  the  system  is  divided  into  three 
major  areas:  hardware  dependencies,  system  characteristics, 
and  system  performance. 

A.  HARDWARE  DEPENDENCIES 

Because  of  hardware  equipment  that  was  selected  the 
following  hardware  dependencies  exist  in  the  current 
implementation  of  the  system: 

1.  The  system  utilizes  an  SBC-310  High-Speed  Mathematics 
Unit  to  perform  floating  point  arithmetic.  Although  as 
discussed  before  the  presence  of  this  math  unit  could  be 
avoided  by  replacing  its  functions  with  appropriate  software 
routines  performing  the  same  operations  using  the  same 
formats,  this  is  not  recommended  because  of  excessive  over¬ 
head  that  would  result,  especially  with  regard  to  the 
execution  time.  Appendix  F  explains  how  the  Math  Unit  was 
actually  implemented. 

2.  The  system  depends  in  three  ways  on  the  type  of 
terminal  used.  The  serial  asynchronous  procedure  necessary 
to  communicate  between  CPU  and  the  terminal,  the  code  needed 
to  control  the  CRT’s  functions,  and  the  general  features 

of  the  DATAMEDIA  Elite  2500  Video  Terminal  notably  the 
programmable  roll  mode,  the  setting  of  privileged  fields, 
the  capability  of  having  an  addressable  cursor,  and  the 
possibility  of  making  displayed  messages  blink. 


3.  The  system  occupies  approximately  13K  bytes  of 
physical  memory  for  code,  and  approximately  3K  bytes  to 
be  used  for  variable  data,  therefore  a  configuration  of 
at  least  16K  bytes  of  RAM  is  necessary  to  execute  the 
system. 


B.  SYSTEM  CHARACTERISTICS 

As  it  was  established  before,  the  system  was  designed 
to  perform  basically  to  solve  the  maneuvering  board  problem 
finding  the  contact  speed  and  course. 

Due  to  interaction  capability  between  modules  as 
allowed  by  the  language  PL/M-80  through  the  use  of  attri¬ 
butes  PUBLIC  and  EXTERNAL  for  the  procedures,  the  following 
list  was  written  in  order  to  show  interactions.  This  list  ^ 
shows  the  modules  which  have  procedures  called  by  the 
listed  module. 


1 .  EXTER 

2 .  INT$DATA 

3.  MAIN $ PROG 

4 .  DISPLAY 

a.  NUMOUT 

b.  DISPLAY$CRT 
C.  CRT$READ 

d.  CHECKS YES$NO 

e.  DISPSERROR 

5.  FLOATINGS POINT 

a.  MUL 

b.  DIV 

c .  EDIV 

d .  FMUL 

e.  FDIV 

f .  FADD 

g .  FSUB 

h.  FSQR 

i .  FLTDS 

j .  FIXSD 


k.  FSQRT 

l .  FCMPR 

m.  FZTST 

n.  COS$SIN 

O .  ARC$TAN 

The  Module  "INT$DATA"  is  used  to  implement  the  radar 
measurements:  range  as  a  yard,  bearing  as  a  degree,  time 
of  measurements  as  a  second  and  their  interfaces  process 
the  system. 

The  "MAIN$PROG"  Module  used  to  perform  the  Kalman  filter 
algorithms,  computation  of  the  filtered  target  course  and 
speed,  display  of  the  result  and  error  performance. 

The  Module  "DISPLAY"  includes'  'the  display  procedures 
on  the  CRT 

The  "FLOATINGS POINT"  Module  is  used  to  perform  the 
floating  point  arithmetic. 

In  order  to  achieve  these  objectives,  a  bottom-up 
implementation  philosophy  was  chosen.  Because  of  the 
modular  design  encouraged  by  PL/M  80  and  ISIS-II,  it  was 
also  possible  to  map  the  different  levels  of  design  into 
corresponding  modules  of  software.  The  basic  idea  was  to 
encompass  all  functions  corresponding  to  a  level  of  design 
into  one  software  module  capable  of  performing  all  the 
necessary  functions. 

C .  SYSTEM  PERFORMANCE 

The  performance  of  the  Kalman  filter  was  evaluated  for 
maneuvering  contact.  The  own  ship  was  proceeding  on  a 


steady  course  (000°)  North  and  at  a  fixed  speed  of  30  knots 
from  an  initial  position  at  the  origin  of  the  cartesian 
coordinate  system  as  shown  in  Chapter  II,  Figure  3.  The 
contact  was  heading  to  060°  true  (North/East)  by  36  knots 
and  its  initial  position  was  009.6°  (North/East),  37,800 
years  from  own  ship. 

The  scenario  has  been  made  to  change  the  contact 
course  and  speed  after  every  15  sets  of  measurements.  The 
approximate  problem  was  solved  on  the  maneuvering  board  and 
by  hand  calculator.  The  first  chance  has  been  made  for 
contact  course  and  speed  which  were  073°  (North/South)  true 
and  50  knots,  respectively,  then  second  reorientation  has 
been  made  to  328°  (North/West)  true  course  and  30  knots 
speed. 

The  accuracy  of  the  computed  course  and  speed  of  the 

contact  will  depend  on  the  tracking  system  parameters  and 

the  maneuverability  of  the  contact.  The  antenna  rotation 

rate  determines  the  mean  time  between  measurements,  which 

in  the  case  of  the  AS-1161/SPS  Antenna  equates  to  3.53 

seconds.  The  majority  of  surface  contacts  will  be  capable 

of  turning  radii  of  100-1000  yards,  velocities  of  0-50 

2 

knots,  and  acceleration  of  0-0.5  yards/sec  .  The  following 

2  2 

Kalman  Filter  measurement  parameters  (o.  and  a  )  were 
used  as  calculated  in  Chapter  IV,  Section  B. 

or2  -  0.0048  nm2 

o92  -  15.988xl0“6  rad2  . 


57 


The  Kalman  filter  initial  conditions  were  the  same  as 

those  discussed  in  Chapter  IV,  Section  C.  The  variance 

2 

of  contact  acceleration  (a.  }  parameter  was  selected  as 

CL 

2  2  4 

o_  =  0.0004  nm  /sec 

cl 

Also  as  is  mentioned  before,  the  variance  of  contact 

2 

acceleration  (o_  )  parameter  is  an  independent  variable  and 
it  is  a  compromise  between  the  user's  desired  smoothness 
of  the  output  data  and  the  ability  of  the  filter  to  provide 
the  closest  estimate  of -a  contact's  position  and  velocity. 

This  parameter  could  be  selected  by  enabling  one  of 
several  read-only  memories  (ROM)  containing  the  desired 
values.  The  particular  ROM  installed  at  any  one  time  could 
be  selected  from  a  library  of  such  ROM's  by  the  Commanding 
Officer,  depending  on  the  ship's  mission. 

The  filtered  outputs  of  the  contact  course  and  speed 
according  to  the  selected  scenario  were  plotted  on  Figure  8 
and  Fiture  9,  respectively.  As  is  noted  on  those  figures, 
the  Kalman  Filter  achieved  a  steady  state  condition  after 
four  to  seven  contact  position  measurements,  corresponding 
to  14.1  and  24.7  seconds  related  to  the  amount  of  reorienta¬ 
tion  has  been  made  on  contact  course  and  speed.  Steady  state 
is  defined  as  the  condition  where  the  Kalman  Filter  Gain 

Matrix  (K  )  would  be  constant  for  contact  with  constant 
n 

relative  position  and  constant  sample  intervals. 
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CONTACT  COURSE  VS.  TIME 


The  bearing,  range,  course,  and  speed  of  contact  was 
computed  from  the  Kalman  filter's  optimal  estimate  of 
contact  state  and  compared  with  the  actual  contact  bearing, 
range,  course  and  speed.  Figures  10,  11,  12,  and  13  show 
plots  of  the  filtered  output  of  the  contact  bearing,  range, 
course  and  speed  errors,  respectively,  as  a  function  of 
the  time  interval  between  measurements. 

Several  conclusions  can  be  made  from  these  figures. 

First  of  all  the  Kalman  filter  initial  conditions  are 
very  much  affected  on  bringing  the  Kalman  filter  to  steady 
state  condition.  Any  information  about  contact  speed  would 
cause  to  shorten  the  time  spent  achieving  a  steady  state 
condition.  Also  selecting  the  variance  of  target  accelera¬ 
tion  parameter  is  as  important  as  initiating  the  filter. 

The  value  of  the  variance  acceleration  parameter  0.0004 
2  2 

nm  /sec  were  chosen  after  many  trials  of  that  selected 
scenario.  It  should  be  noted  that  the  error  averages  for 
contact  are  a  function  of  the  elapsed  time  between  maneuvers 
and  the  time  spent  in  maneuver. 
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BEARING  ERROR  VS.  TIME 


VI .  CONCLUSION 


A  microcomputer-based  tracking  system  has  been  developed 
that  eliminates  an  inaccurate  and  tedious  task  of  manual 
tracking,  for  any  ship,  without  the  expense  of  NTOS  size 
equipments,  with  digital  automatic  surface/subsurface  capa¬ 
bility. 

It  is  possible  to  obtain  optimal  estimates  of  contact 
position  and  velocity,  with  the  aid  of  the  4-state  Discrete 
Kalman  Filter  and  appropriate  conversions  for  polar  coordinate 
measurements.  Thus  the  contact  course  and  speed  computations 
were  successfully  performed  by  using  the  Intel  intellec  MOS 
microcomputer  system,  much  more  accurately  than  manual 
tracking  techniques. 

The  SBC-310  High  Speed  Mathematics  Unit  has  been  selected 
based  on  a  standard  floating-point  number  format  with  24 
bit  mantissa,  7  bit  exponent  and  a  sign  bit  by  comparing 
execution  times  of  procedures  to  perform  sufficient  accuracy 
to  reliably  compute  the  Kalman  Filter  Algorithms  and  con¬ 
version  factors. 

The  total  average  of  the  system  execution  time  was 
approximately  50  msec  and  with  the  3.5  sec  sweep  of  an  AS- 
1161/SPS  radar  antenna,  a  single  system  could  continuously 
provide  bearing,  range,  course  and  speed  data  for  more  than 
fifty  contacts  by  modifying  the  software  program. 


For  future  work  it  is  possible  that  the  system  could 
compute  a  contact's  closest  point  of  approach  (CPA)  and  could 
display  as  (1)  CPA  Bearing,  (2)  CPA  Range,  and  (3)  Time  of 
CPA  by  a  more  sophisticated  software  study. 

The  system  can  be  a  valuable  tool  aboard  non-NTOS  ships 
as  implemented.  A  microprocessor-based  system  such  as  the 
one  described,  has  the  potential  to  provide  any  ship  with  a 
digital  surf ace/subsur face  tracking  capability  without  the 
expense  of  NTOS  size  equipment.  It  can  reduce  the  manning 
of  underway  watches  while  improving  the  quality  of  the 
tactical  information  available  to  the  Officer  of  the  Deck. 
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APPENDIX  A 


Intel  SBC-310  High  Speed 
Mathematical  Unit  Descriptions 

A.  GENERAL  INFORMATION 

The  floating-point  package  developed  for  this  system  is 
based  on  the  SBC-310  High-Speed  Mathematics  Unit  fromlntel 
Corporation.  As  described  by  Reference  1,  the  SBC  310  Unit 
is  a  member  of  a  complete  line  of  the  Intel  SBC  80  System 
expansion  modules.  In  performing  high-speed  mathematical 

J 

functions,  the  Math  Unit  acts  as  an  intelligent  processor 
slaved  to  one  or  more  SBC  80  Computer  Masters.  The  Mathe¬ 
matic  Unit  performs  its  repertoire  of  14  arithmetic  functions 
an  order  of  magnitude  faster  than  is  possible  with  software 
routines . 

B.  DESCRIPTION  OF  THE  MATH  UNIT 

The  Math  Unit  is  a  microprogrammed  processor  on  a  single 
board  and  is  designed  to  be  plugged  into  a  standard  SBC 
604/614  Modular  Backplane  and  cascade  to  interface  directly 
with  an  SBC  80  single  board  computer  or  to  be  used  with  an 
Intel  Intellec  Microcomputer  Development  System  CMDS) . 

The  Math  Unit  includes  the  following  standart  Intel  Series 
300  shotthy  bipolar  components;  3001  Microprogram  Control 
Unit  (MCU) ,  3002  Central  Processing  Element  CCPE) ,  3003  Look- 
Ahead  Carry  generator  (LCG) ,  and  3604  Electrically  Programmable 
Read  Only  Memory  tPROM) .  Also  included  are  pipe  line  register 


and  bus  interface  logic.  The  pipeline  register  permits  the 
overlapping  of  microinstruction  fetch/execute  cycles  and  the 
bus  interface  logic  provides  compatibility  with  the  Intel 
Multibus. 

Standard  Operations  include  floating  point  add,  subtract, 
multiply,  divide  square  and  square  root;  fixed  point  integer 
multiply,  divide,  and  extended  divide;  conversion  between 
fixed  and  floating  point  representations;  and  test,  compare, 
and  argument  exchange  operations . 

The  Math  Unit  implements  unbiased  rounding  for  maximum 
accuracy.  Unbiased  rounding  is  the  same  as  ordinary  rounding 
unless  the  result  is  exactly  midway  between  two  floating 
point  numbers;  in  this  case  ordinary  rounding  always  increases 
the  result,  whereas  unbiased  rounding  rounds  the  result  to 
the  nearest  even  number.  When  a  calculation  is  performed 
that  results  in  either  an  exponent  underflow  or  overflow,  the 
Math  Unit  provides  exponent  wraparound  to  prevent  loss  of 
information. 

Operation  Codes  for  invoking  the  arithmetic  functions  are 
passed  to  the  Math  Unit  via  I/O  Write,  Commands,  which  are 
also  used  to  initialize  the  unit  with  a  memory  base  address. 

I/O  read  commands  are  used  to  determine  the  math  unit  status. 
Arguments  are  passed  to  the  Math  Unit  via  Memory  Write, 

Commands  and  the  results  are  obtained  via  Memory  Read  Commands. 

The  Math  Unit  which  can  be  operated  either  in  the  Inter¬ 
rupt  of  Polled  mode,  generates  a  busy  signal  during  processing 
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operations  and  generates  either  a  complete  signal  or  an  Error 
signal  after  the  computation  is  complete.  The  information 
to  the  host  computer  which  these  three  signals  convey  is 
explained  in  Ref.  (1) . 

The  memory  base  address  and  I/O  base  address  are  user 
selectable.  The  16-bit  memory  address  is  completely  under 
software  control  and  is  assigned  by  the  host  processor  through 
a  sequence  of  I/O  Write  Commands,  addressed  to  the  Math  Unit. 
The  8  bit  I/O  base  address  is  selected  by  a  dual  inline 
package  (DIP)  switch  on  the  board. 

All  Math  Unit  operations  including  arithmetic  calculations, 
data  flow  between  functional  elements  on  the  board  bus  inter¬ 
face,  and  associated  logical  tasks,  are  resident  microprogram 
permanently  stored  in  a  set  of  eight  Intel  3604  Erasable 
Programmable  Read  Only  Memory  CEPROM)  chips.  This  memory 
provides  1,024  micro-instructions  of  32  bits  each. 

C.  PREPARTION  FOR  USE 

1.  installation  Consideration 

The  Math  Unit  is  designed  for  interface  with  an  Intel 
SBC  80  single  board  computer  based  system  or  an  Intel  Intellec 
Microcomputer  Development  System  (MDS) . 

When  installing  the  SBC  310  in  an  Intel  Intellec  MDS, 
the  CPU  board  needs  to  be  reconfigured  in  order  to  generate 
a  Qualified  Write  Signal;  this  reconfiguration  was  obtained 
by  considering  the  advanced  acknowledge  (AACK)  feature  by 
moving  a  jumper  labelled  "advanced  write"  from  a  D-C  connection 


to  an  E-D  connection  and  by  disabling  the  AACK/LINE  (pin  25) 
on  the  CPU  board  as  shown  in  the  schematic  diagram  on  page 
3-47  of  Reference  4. 

2.  I/O  Base  Address  Switches 

The  host  processor  transmits  control  information 
and  receives  status  information  from  the  Math  Unit  by  issuing 
I/O  Write  and  I/O  Read  Commands,  respectively.  The  I/O 
address  used  for  these  commands  is  relative  to  an  8-bit  base 
address  that  must  be  a  multiple  of  8.  This  base  address  is 
assigned  by  the  user  by  means  of  an  8-pole  dual  inline  package 
(DIP)  switch  assembly.  Five  of  the  eight  switch  poles  are 
connected  to  the  I/O  base  address  detection  logic;  the  other 
three  poles  are  unused. 

The  Math  Unit  had  used  its  DIP  switch  set  to  the 
I/O  base  address  of  10  hexadecimal  (only  switch  pole  no.  4 
was  set  on) . 

3.  Programming  Information 

The  I/O  base  address,  which  must  be  assigned  by  switch 
selection  before  the  memory  base  address  can  be  assigned,  is 
normally  performed  as  part  of  the  initial  installation  proce¬ 
dure.  This  switch  setting  allows  the  user  to  establish  a 
reference  or  base  to  the  ports  being  used  in  the  I/O  opera¬ 
tions;  Table  7  shows  the  configuration  of  the  I/O  addressing 
as  it  was  set  in  the  system. 

The  memory  base  address,  which  is  software  controlled, 
is  assigned  by  a  sequence  of  two  I/O  write  Commands.  The 
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I/O  PORT 
ADDRESS 

OUTPUT 

INPUT 

P  *  010H 

OP  CODE 

R 

P+1  »  011H 

MEM.  LOW 

STATUS  BYTE 

P+2  »  012H 

MEM.  HIGH 

R 

P+3  =  013H 

R 

R 

P+4  a  014H 

R 

R 

P+5  *  01 5H 

R 

R 

P+6  *  016H 

R 

R 

P+7  =  01 7H 

R 

FLAG  BYTE 

P:  I/O  BASE  ADDRESS 

R:  RESERVED 

OP  CODE:  MATHEMATIC  FUNCTION;  See  Table  4 

MEM.  LOW:  Memory  BASE  ADDRESS  (Lower  Byte) 

MEM.  HIGH:  Memory  BASE  ADDRESS  [Upper  Byte) 

Table  7.  I/O  ADDRESSING  OF  SBC- 310  HIGH  SPEED  MATH  UNIT 
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first  command  is  addressed  to  port  (P+1)  and  loads  the  low 
order  byte  of  the  memory  base  address.  The  second  command  is 
addressed  to  port  (P+2)  and  loads  the  high  order  byte  of  the 
memory  base  address.  The  memory  base  address  must  be  a 
multiple  of  16;  i.e.,  the  lower  byte  must  be  in  the  form  XOH 
(X  is  any  hexadecimal  digit)  to  accommodate  the  16  required 
memory  locations  used  in  the  arithmetic  operations.  In  the 
system  developed  for  this  thesis  the  memory  base  address  was 
set  of  0F790H.  After  both  bytes  are  output,  the  memory  base 
address  (M)  is  established  and  need  not  be  reloaded  during 
any  subsequent  operations.  An  initialization  routine  for 
establishing  the  memory  base  address  was  designed  and  it  can 
be  seen  in  the  "INIT$FP"  procedure  in  the  floating  point 
module  (see  "FLOATING$PINT"  module  in  Appendix  F) . 

4.  Math  Unit  Functions 

The  Math  Unit  performs  floating  point  arithmetic, 
fixed-point  integer  arithmetic,  compare  and  test  operations, 
and,  float-to-fix  and  fix-to-float  conversions.  Operation 
Codes  and  execution  times  for  the  various  functions  are 
listed  in  Table  4.  Arithmetic  and  conversion  formats  are 
shown  in  Table  8. 

Beyond  the  functions  performed  by  the  Math  Unit, 
the  floating-point  package  was  designed  with  two  more  proce¬ 
dures  which  compute  the  cosine  and  sine  of  a  given  angle  and 
the  arctangent  value  of  the  ratio  of  given  arguments. 
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SINGLE  PRECISION  FLOATING  POINT 


Mf3  m2 

S7  0  22  16 


Mfl  M 

15  8  7  0 


exponent  ^i«ry  point  fractiQn 
8  bits  23  bits 

where:  M:  Memory  Base  Address 

S:  *0"  =  positive;  "1"  =  negative 

E7-E0:  Biased  exponent;  Bias  -  07m. 
F22-PO:  Fraction;  F  is  always  normalized 


FIXED  POINT  INTEGER 


binary  point 

where:  M:  Memory  Base  Address 

F15-F0:  16-bit  integer  (msigred) 


CONVERSION  FUNCTION 


31  2423 


where:  M:  Memory  Base  Address 

S:  "0"  «  positive;  "1"  **  negative 

F30-F0:  two's  corrplenent  integer 


binary  poin 


I 


5.  Argument  and  Result  Data  Formats 

Argument  and  result  data  formats  and  memory  locations 
for  the  various  operations  are  presented  in  Table  9.  For  each 
argument  and  result,  this  table  includes  a  Format  number 
cross-referenced  to  one  of  the  four  formats  shown  in  Table  8. 
Table  9  also  includes  the  OP  CODE  for  each  operation.  It  is 
important  to  note  that  the  result  of  an  operation  replaces 
the  first  argument  in  memory,  and  that  the  second  argument 
may  be  destroyed  in  the  course  of  the  computation,  these 
side  effects  were  avoided  in  the  floating-point  software 
design  by  saving  the  original  values  and  by  allowing  the 
user  the  possibility  of  having  one  of  the  operands  as  the 
result.  Error  conditions  for  each  operation  are  described 
in  the  next  paragraph. 

6.  Status  and  Flags 

The  Math  Unit  may  be  operated  in  the  interrupt  mode 
or  piled  mode. 

In  the  interrupt  mode,  the  Math  Unit  may  be  wire- 
wrapped  to  initiate  an  interrupt  request  under  one  or  both 
of  the  following  conditions: 

a.  Operation  Complete  without  an  error. 

b.  Operation  Complete  with  an  error. 

These  "completion"  signals  may  be  individually  wire"- 
wrapped  to  separate  interrupt  lines  or  both  "completion" 
signals  may  be  wire-wrapped  to  the  same  interrupt  line  (Reference 
1). 
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1  8  i  P  am 


In  the  polled  mode,  the  subroutine  designed  fo  ithis 
purpose  checks  both  the  status  byte  and  the  flag  byte  (Tables 
10  and  11) .  The  polled  mode  procedure  loops  on  testing  the 
busy  bit  until  the  busy  bit  is  clear  and  then  checks  the 
error  bits.  If  an  error  exists,  the  error  code  is  input  from 
the  Math  Unit  and  a  message  error  is  issued.  The  software 
has  developed  for  control  of  the  Math  Unit  if  the  system 
employs  the  polled  mode  described. 

As  mentioned  before,  the  condition  of  the  Math  Unit 
is  continuously  updated  and  stored.  The  flag  byte  shown  in 
Table  10  may  be  obtained  by  performing  an  I/O  Read  Command 
to  Pt  7  (Table  7).  After  an  operation  is  completed,  the 
status  byte  may  be  obtained  by  performing  an  I/O  Read  Command 
to  P+L  (Table  7) . 

As  shown  in  Table  (11) ,  the  status  byte  indicates 
error  conditions  where  applicable  and  the  results  of  compare 
(FCMPR  procedure)  and  Test  (FZTST  procedure)  operations. 

Each  of  the  six  error  conditions  are  defined  as  follows; 

a.  Divide  by  Zero;  (001) 

This  error  condition  is  returned  by  either  "DIV", 
"EDIV",  or  "FDIV"  procedures  to  indicate  that  an  attempt  was 
made  to  divide  by  zero. 

b.  Domain  Error  (010) 

This  error  condition  is  returned  by  the  "FSQRT” 
procedure  to  indicate  that  the  argument  was  not  in  the  domain 
of  the  function;  i.e.,  an  attempt  was  made  to  take  the  square 
root  of  a  negative  number. 


77 


7  6543  210 


E 

R 

R 

R 

R 

E 

C 

3 

where : 

R  is  reserved  for  future  use 
B  is  busy 

C  is  operation  complete  without  error 
E  is  operation  complete  with  error 


when  B  »  1,  the  Math  Unit  is  busy  and  can  not 
respond  to  further  request  except  request  for 
flags. 


Table  10,  FLAG  BYTE  FORMAT  FOR  SBO310 


7654  3  2  1  0 


where ; 

R  is  reserved  for  future  use 
»  is  equal  (for  FCMPR  and  FZTST) 

>  is  greater  than  (for  FCMPR  and  FZTST) 

<  is  less  than  (for  FCMPR  and  FZTST). 

ERR  is  a  3-bit  error  code  specifying  one  of 
the  following  error  conditions, 

Q00  No  error 

QQ1  Divide  by  Zero 

Q10  Domain  Error 

Oil  Over  flow 

100  Under  flow 

1Q1  First  argument  invalid 

110  Second  argument  invalid 

111  Reserved 


Table  11.  STATUS  BYTE  FORMAT  FOR  SBO-31Q 
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c.  Overflow  (Oil) 

This  error  condition  is  returned  by  the  "FADD", 
"FSUB" ,  "FMIL",  "FDIV" ,  "FSOR",  and  "FIXSD"  procedures.  In 
the  case  of  "FIXSD"  procedure,  this  error  indicates  that  the 
floating-point  number  is  too  large  to  be  converted  to  a  32 
bit  two*s  complement  signed  integer.  If  an  overflow  error 
occurs  during  "FIXSD",  the  floating-point  argument  is  left 
unchaged  and  may  be  read  from  the  Math  Unit. 

In  all  other  cases,  this  error  condition  signifies 
that  the  exponent  of  the  result  is  too  large  to  be  repre¬ 
sented  in  eight  bits.  In  this  case,  OBEH  is  subtracted  from 
the  resulting  exponent  (bringing  it  back  into  range  for  other 
computations  and  ensuring  a  valid  result) ,  and  the  lower 
eight  bits  of  the  exponent  are  returned  in  the  exponent  field 
of  the  result. 

d.  Underflow  (100) 

This  error  condition  is  returned  by  "FAOO", 

"FSUB",  "FMUL" ,  "FDIV",  and  "FSQR"  procedures  to  indicate 
that  the  exponent  of  the  result  is  too  small  to  be  represented 
in  eight  bits.  In  this  case  OBEH  is  added  to  the  resulting 
exponent  bring  it  back  into  range  for  other  computations  and 
ensuring  a  valid  result,  and  the  lower  eight  bits  of  the 
exponent  are  returned  in  the  exponent  field  of  the  result. 

e.  First  Argument  Invalid  (101) 

This  error  condition  is  returned  by  the  "FADD", 
"FSUB",  "FMUL",  "FDIV",  "FSQR”,  "FSQRT",  "FIXSD",  "FCMPR", 
and  "FZTST"  procedures  to  indicate  that  the  first  (or  only) 


argument  for  the  specified  function  is  invalid.  The  second 
argument  (if  applicable)  is  not  checked  if  this  error  is 
encountered.  The  invalid  argument  is  left  unchanged  and 
may  be  read  from  the  Math  Unit. 

f.  Second  Argument  Invalid  (110) 

This  error  condition  is  returned  by  the  "FDD”, 
"FSUB" ,  "FMUL" ,  "FDIV"  and  "FCMPR"  procedures  to  indicate 
that  the  second  argument  for  the  specified  function  is 
invalid.  This  error  condition  occurs  only  after  the  first 
argument  is  checked  and  found  valid.  The  invalid  argument 
is  left  unchanged  and  may  be  read  from  the  Math  Unit. 

Notes : 

(1)  The  floating-point  argument  may  be  expressed 

as : 

(1)  x  (2E  -  BIAS)  x  (l.F) 

Notice  that  a  "1"  is  assumed  in  the  highest  position  of 
fraction. 

(2)  There  is  one  unique  representation  for  zero; 

S  =  0 

E7  -  E0  =  0 

F22  -  F0  =  0 
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(3)  The  following  representations  are  invalid. 

(a)  Assures  unique  representation  of  zero 

E7  -  EO  =  0  ,  and 

S  M  or  F22  -  PO  =  0 

(b)  Reserved  for  future  enhancements 

E7  -  EO  =  OFFH 

7.  Examples  of  Floating-Point  Number"  Representations 

As  shown  in  Table  8  the  representation  of  a  floating¬ 
point  number  has  one  particularity  that  needs  to  be  men¬ 
tioned;  i.e. ,  a  "1"  is  always  assumed  in  the  highest  bit 
position,  and  then  it  yields  an  effective  24-bit  mantissa. 

For  the  sake  of  clarity  some  examples  are  given  in  Table  12. 


F.P.  Number 


M 


M+l 


M+2 


M+3 


-  INFINITY 

OFFH 

OFFH 

OFFH 

OFFH 

-  255.0 

OOH 

OOH 

07FH 

OC3H 

5.0 

00  H 

OOH 

OAOH 

OCOH 

1.0 

OOH 

OOH 

080H 

08FH 

0.0 

OOH 

OOH 

OOH 

OOH 

+  1.0 

OOH 

OOH 

08  OH 

+  5.0 

OOH 

OOH 

OAOH 

04QH 

+  255.0 

OOH 

OOH 

07FH 

043H 

+  INFINITY 

OFFH 

OFFH 

OFFH 

07FH 

IT 

ODBH 

OOFH 

04  9H 

040H 

* 

OFFH 

OFFH 

07FH 

07FH 

** 

OOH 

OOH 

08  OH 

OOH 

1.07  xlO9  *** 

OFFH 

OFFH 

07FH 

04BH 

This  is  the  largest  number  in  the  single-precision 
floating-point  format. 

**  This  is  the  smallest  positive  number  in  the  single 
precision  floating-point  format. 

***  This  is  the  largest  number  that  can  be  converted 
to  floating  point  without  losing  accuracy. 

Table  12.  FLOATING  POINT  NUMBERS 
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APPENDIX  B 


System  Start-Up  Procedure 

Caution:  Never  turn  on  or  of£  the  diskette  drive  with 
a  diskette  inserted  ! ! ! 

1.  TURN  ON  MDS  SYSTEM.  Use  the  key  located  at  the  upper 
left  corner  of  the  front  panel  and  turn  it  clockwise. 

The  power  indicator  should  light. 

2.  TURN  ON  DISKETTE  DRIVE.  Use  power  switch  located  at  the 
front  panel.  The  on  indicator  should  light. 

3.  TURN  ON  DATAMEDIA  TERMINAL  CCRT)  .  Use  switch  located 
on  right  side.  The  cursor  should  appear  at  the  screen 
after  a  few  seconds.  Ensure  that  the  lights  CD,  CTS, 

ROLL  and  FULL  DUPALLEX  are  on. 

4.  PLACE  SYSTEM  DISKETTE  IN  DIRVE  0  and  the  source  diskette 
in  drive  1,  with  the  read/write  access  slot  first.  Close 
door  of  the  drives  after  insertion. 

5.  BOOTSTRAP  THE  IS IS -I I  OPERATING  SYSTEM. 

a.  Press  top  of  the  Intellec  BODY  Switch. 

b.  Press  top  of  the  RESET  Switch. 

c.  Observe  that  INTERRUPT  2  INDICATOR  goes  on  before 
proceding. 

d.  Press  space-bar  of  Datamedia  video  terminal  keyboard. 

e.  Observe  that  INTERRUPT  2  indicator  goes  off  before 
proceding. 

f.  Press  bottom  of  BOOT  Switch. 
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g.  Observe  that  the  following  message  appears  at  the 
Datamedia  Video  terminal  screen: 

ISIS-II,  V3.4 

6.  Issue  the  following  Command: 

-  ;F1:  FATIH 

7.  After  a  few  seconds,  the  Datamedia  Video  terminal  screen 
will  show  the  first  computation  of  COURSE,  BEARING, 

RANGE,  SPEED,  THE  KALMAN  FILTER  GAIN  MATRIX  ELEMENTS,  AXX, 
AXY ,  AYX,  AYY ,  BXX,  BXT,  BTX,  BYY  and  the  FILTER  Error 
Performance  DELTA  RANGE,  DELTA  BEARING,  DELTA  RANGE  DOT, 
DELTA  BEARING  DOT  and  following  message  appears  at  the 
screen: 

NEXT  ?  (Y/N) 

8.  PRESS  THE  LETTER  'Y'  and  see  *YES *  message  appear  on  the 
screen  to  compute  next  measurement. 
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APPENDIX  C 


AN/SPS-10  Search  Radar  Characteristics 
with  AS-1161/SPS  Radar  Antenna 


Peak  Power, 

Antenna  Gain, 

Pulse  Repetition  Rate 
Frequency 

Propagation  Attenuation 

Noise  Figure 

Band  width 

Noise  Bandwidth 

System  tosses 

Antenna  Rotation  Rate 

Antenna  Horizontal  Beamwidth 


190  KW 
30  dB 
625  Hz 
5825  MHz 
0.6  x  10“ 
22.9  dB 
5  MHz 
(1.05  x  B) 
5  dB 


dB/m 


5.25  MHz 


17  rpm 
1.9° 
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APPENDIX  D 


Algebraic  Form  of  Discrete  Kalman  Filter 

1.  COVARIANCE  MATRIX  FOR  THE  OBSERVATION  NOISE 

«i<“> 

Rn  “ 

%y<nl  '  °y(n) 

o2(n)  ■  of  •  sin26(n)  +  r2  (n)  *o?  •  cos20(n) 

x  r  o 

o2(n)  ■  o2  •  cos20(n)  +  r2(n)  *  a2  •  sin20(n) 

a^y(n)  *  j  •  sin  20  (n)  •  [a2  -  r2(n)o2] 

2.  THE  GAIN  MATRIX 

K  =  P (n)  *  Hfc  • (H*P (n) *HT  +  R_) _1 
n  n 
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/*  8.  BTY/T  =  fPD43  *  PB11X  -  PB41  *  PB13XY )  /  DELTA 

150  2  CALL  TMUL  ( .PP43, .PP11X,  .BYY)» 

151  2  CALL  FMUL  ( .PB41 , .PB13XY , .TEMP) J 

152  2  CALL  ?SUB  (. BYY , .TEMP , .BYY  )  J 

153  2  CALL  ?!)!¥  (  .BYY ,  .DELTA,  .BYY  )  J 
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180  2  CALL  FMUL  f .PM4, .BXX , .PA24 )  ? 

181  2  CALL  FMUL  ( .PB34, . FXT , .TEMP ) i 

182  2  CALL  FADE  ( .PA24, .TEMP, .PA24) J 

183  2  CALL  FSUP  ( .PB24, ,P*24, .PA24) ; 


K 

>-*  •• 

M 

to  ••* 

X 

to  •» 

X 

to  •• 

to 

to 

po 

* 

to 

x<^ 

CM 

■«;  ■ — ■ 
to 

tol  to- 

vH 

*  IQ  — 

*  to 

*  to  ~ 

•»  to 

to 

m  m 

X 

tol  •- 

X  ••>•“> 

to  •« 

(O 

•  »  •  to 

to  pq  H— -  to 

CM  Ah  ■<■-*  CM 

tO  Ah  to- to 

P-H—  4, 

Ah 

H  H 

tot  •  Ah  to 

to  •  A-  tO 

to  •  Ah  tO 

to  •  Ah  to 

H-l  A  Tt*H|* 

pq  *  r:  x 

pq  •  Z.  ■« 

PC  *>Z  * 

PP  *r  -q 

| 

■*  z:  x  x 

Ah  to*  (to  Ah 

A*  to  W  Ah 

Ah  >-.  W  A* 

A,  to  P^*  Ah 

tol  pq  Ah  Ah 

to  6- <  • 
I  rr.  .  • 
r/>  -  Ah 

xr 

to  z  top a 
«.  O  ■«.  6h 
vv  •  •  ■ 

(W  •  •  • 
ZHHrt 
OtO  totO 
(O  pOtol 
*  Ah  A.PU 


-H/V  -  A* 
^MKE 
to  Z  to  Pm 
«:  O  «  6- 
W  •  •  • 

(»)•*» 
2WNN 
O  tO  to  to 

(*l  (**  X 

*  a,  a-  to 


w  *p< 
to  (WK  Z 
to  z  to  W 
<  O  <  E-* 
w  *  •  • 
M  *  -  • 

z  to  to  to 
O  to  ^  to 
pq  po  *«. 

E  P»Pi  P< 


X  A,  E-*  •  • 

pq  •  *p<  h 

k  to  z:  ** 
< 

pq  pq  E->  Ah 


pq  *-»  »h  *h  »-t 
(to  to  «o  •* 

pq  pq  «3  «a 

|  (to  (to  Ah  (to 


po  ,j  h3  pq  pc  *J  »J  pq  pq  hJ  to)  pr.  pq  ,j  ,-q  pq  pq  _l  to  (=.  A) 
(to  DBS  (tD  P  D  It*  DD  D  (to  B  B  B  P.DDPD 


z:  r«o 

it  ^  ^  ^ 

r*  tot  to  to 
tO  tol  tot  tot 
X  «:  X  X 
(to  U  C  U 


riw 
n  (to  (to  p.. 

CM  to  to  to 

to  tol  tot  tot 
x  x  x  x 
COUP 


z:  r  to 

II  ^  (to  Pm 

to  tol  tol  tot 

to  to)  tol  tot 

X  X  X  X 

p*coc 


z;  t.  to 

II  (to  (to  (to 


Z  Z  tq 
II  (to  P**  (to  (to 


tot  tot  tot  to  to  tot  to  l-t 

tO  tto  tot  tot  ^  tot  tot  tol  tot 

x  x  «  x  <■;  x  x  «  x 

(to  u  (to  o  q.  o  tto  t_'  o 


CM  CVJ  CM  CM  CM  CM  CM  CM  CM  CM  CM  CM  CM  CM  CM  CM 


if)  (O  D-  CO  Cft  ®  to  CM  (O  X  if)  IDMllOl 

CD  CD  CD  CO  CD  Uv  O)  0)  05  05  O)  0)  0)0)0  0) 


a 


me* 


I 

r. 

n 


!.  i 

V 

-  . 

« 

* 

* 

>•  , 

;  | 

>- 

>* 

>4 

►« 

>~ 

x 

1 

PR 

PR 

PR 

|W'- 

« 

# 

# 

* 

CM 

to 

4*4 

■  * 

tO  •“  ••> 

to  ••  •- 

to  •— 

CP  ••  •• 

PR  •*  ••  —  — 

PR  *»  •»  '—  ' — ' 

CP'——  CM  CM 

CP  — —to  tO 

CP - —  4*4  4*4 

CM  A  4*  ,*4 

to  A  4*  4*4 

,*4  A  4*4 

I  x  <  •< 

i  «i* 

1  <«•  X  -P  «- 

«;  C*1  CP  A 

«;  ps  CP  CP 

«,  pi>  CP  CP 

X  CP  E-1  •  • 

K  A  6"*  •  • 

X  A.  6-4  •  • 

f 

>-!•••• 

H  *  •  *  * 

X*  •  •  •  •* 

PM  -  » CP  CM 

PR  »  -  A  tO 

A  •  •  CP  ^4 

mx  x 

KPZ^ 

X  X  X  ■* 

#  X  ►«  W  «■ 

*  pa  «, 

*  X  A  w  «. 

. 

pci  ps  e-.  cp 

pc  cd  e-t  cp 

pc  pn  E-  CP 

N  •  •  •  • 

to  •  •  •  • 

^  •  •  •  • 

H  »  •  *  • 

H  •  *  *  * 

H  •  •  •  • 

CP  CM  CP  CP  CM 

PP  to  to  to  to 

CP  4*4  -4f4  -4»4  M4 

► 

CP  41  tO 

A  4-4  to  4*4  4*4 

A*  4-4  to  M4  ■* 

CD  pc.  «B  PC: 

PR  PR  <<  PR 

CD  CD  •«:  pn 

1  CP  CP  CP  A- 

1  A-  CP  CP  CP 

1  A  A  A  A 

«  •  •  « 

4  •  «  « 

4  •  4  f 

CM  —  —  — 

tO  —  —'  — 

4*4  ’ — -  —  — 

1 

CPtJi-J  O  CP 

PtJPIRP. 

P  tJt-l  RPC 

ai 

as  » «s 

RDbPS 

RSSRD 

x  x  «:ot 

ir<m 

It  <w 

i 

II  h  |P  hln 

II  A  A  A  A 

II  A  A  A  A 

i 

w 

cm  nn  nn 

ICPRPIO 

nn  nn 

1 

! 

o 

*4  *J  t-»  X 

•4*4  ►J  ►-!  >-R  PR 

I. 

-» 

•r  *“■  «e  R!  «- 

f 

i 

CP 

ftOCCO 

CP  Ci  O  O  CP 

ROC  OR 

1  \ 

• 

*< 

If) 

• 

<c 

os 

* 

* 

* 

A 

\ 

s 

• 

l 

n 

4-4 

A 

X 

o 

o 

CM  CM  CM  CM 

CM  CM  CM  CM 

CM  CM  CM  CM 

1 

Si 

cu 

X 

«.  4-4  CM  tO 

to  p- 

a,  05  ta  4-i 

—s 

S  S 

5.  ®  S3  & 

Ci  S  4-1  4-4 

n 

A 

CM  CM  CM  CM 

CM  CM  CM  CM 

CM  CM  CM  CM 

* 

* 

S3 

* 

* 

o 

* 

» 

p 

« 

* 

* 

O 

■* 

s 

« 

6-< 

* 

* 

* 

H* 

V. 

« 

« 

* 

Eh 

* 

* 

O 

* 

■» 

l-H 

« 

o 

* 

ou 

« 

l-H 

p- 

* 

CO 

\ 

# 

* 

« 

o 

* 

to 

* 

+ 

to 

* 

tx; 

* 

Eh 

* 

o 

*■ 

o 

« 

as 

* 

CO 

* 

* 

p 

» 

Eh 

o 

* 

pa 

* 

IB 

* 

* 

* 

Eh 

CM 

» 

z 

* 

* 

o 

* 

CM 

V 

P 

« 

l-H 

* 

CM  — 

« 

* 

«e  — 

to  *- 

+ 

« 

* 

H  ••  »r  •• 

£h  r-*  •  »  mm 

* 

r 

* 

H  «— s 

<«  CM  — ■ 

Eh 

# 

l-H 

* 

+  (Xi  **—  H  (Xt  iH  *H 

O  rH  CM  CM 

* 

E- 

« 

P  ®t  rt  r  ••  p  »H 

l-H  CL*  rH  «-H 

* 

« 

CO 

* 

EH  •  r  pp  p— ~  p  pi 

CO  P- —  P  Pi 

» 

w 

* 

—  -  W  P  s-.  P  p  P 

•  p  p.  p 

* 

* 

rHpstn  •  •  £  •  • 

+  -£  •  • 

r 

» 

p 

# 

N  S3  <  *  ►  W  ►  ► 

o  pa  »  - 

rH 

« 

tt;  • 

* 

■*3  O  *P  Hfr<  P  n 

H»eiPN 

«r 

« 

E-  Z 

* 

P  P  9  £  CM  •  £  « 

Eh  •  £  H 

p 

* 

o 

« 

+  •  to  Pa  «.  -Pa  c 

*  •  -pa  «: 

+ 

f*«  l-H 

« 

CM  -fH  E-  P  Eh  E«  P 

-Eh  6-  P 

to 

* 

06-* 

« 

CM  10  •  •  • 

CM 

# 

■< 

* 

CM  Eh  -  *  - 

■< 

* 

K> 

« 

P  «W  HWArl  rt 

<  «N  (M  (V 

P 

* 

►h  PS 

# 

—  O  CM  rH  f-H  £  n  rH 

a-  cscm  n  h 

* 

P  p 

* 

►h  «s  p  «  &a  p  « 

HH  -<  P  P 

* 

E-  (O 

# 

+  (OPPPEhPP 

+  CO  P  P  P 

+ 

* 

-t  p 

* 

•  •  •  • 

* 

£0 

* 

H  www  w 

CM  w  — ^  w 

to 

* 

* 

rH 

rH 

rH 

* 

pa  p 

* 

OiapphSCt 

Ot4PP 

-s 

•* 

O  f£ 

* 

fcMOPPDPP 

P  rH  O  p>  P 

p 

* 

Z  e- 

* 

C  £«■«£«•  «. 

P  £  -  -t. 

* 

* 

II  p  p,  p  p  P  P  p 

li  p  p  p  p 

n 

* 

►HO 

* 

•K* 

P  z 

* 

rH  hi  |J  ri  ►]  rS  ►S 

CM  rJ  r4  *-1  PS 

to 

* 

1-4 

* 

PlJi-lppJPlJ 

rH  r-i  P  P  P 

rH 

* 

s»  to 

* 

PQ«s»<«;«r.  -G«-«r 

PP  «*:  C  >*-  «: 

p 

* 

O  CO 

* 

POOOOOOO 

P  O  CJ  o  o 

p 

*• 

o  pa 

* 

o 

* 

• 

• 

• 

* 

pa  o 

* 

CM 

to 

Hr 

K  PS 

* 

E-  Pi 

«• 

i 

* 

* 

* 

* 

N* 

*  *  * 

\ 

N 

lO  tO 

>  fti  H  H 

■r 

lHH.h 
i  e-  •  • 
i  •  -  - 

i  •  P  CO 
'Olrt 

►  to  P  •< 


to  to 

W  HH 
I  «.  p  P 
P  P  P 


I^PP 
E=>  P  P> 
£  «■  ■< 
p  p  p 

p  pp 
ip  pp 

,  •  «c  «S 

O  CJD 


NN  N  N  (M  W  N 


CM  CM  CM  CM 


CM  CM  CM  CM  CM 


CM  tO  ^  tf5  CO  t>  00 

rip  P  HH  P  H 
CM  CM  CM  CM  CM  CM  CM 


05  <S>  «-*  CM 
rH  CM  CM  CM 
CM  CM  CM  CM 


to^mtop- 
CM  CM  CM  CM  CM 
CM  CM  CM  CM  CM 


/*  4.  PB14  =  P*14  +  PA24  *  T 

228  2  CALL  FMUL  ( .PA24  f .T, .PB14) » 

229  2  CALL  ?*DD  (  .PB14  ,  .PA14, .PB14  ) 


I  - - 


* 

O 

CO 

r  ■ 

6i 

o 

* 

» 

\ 

CM 

! 

£- 

\ 

* 

m< 

N 

-> 

■< 

* 

- 

? 

\ 

P> 

to  — 

+ 

•* 

■  CM 

•  V. 

•  « 

•  «P 

* 

•<  TH  — « 

CM 

4—N 

E-I  •-  — 

o  cm  *-h  *■« 

PP 

to 

■* 

CM 

t-i  pa  •  -  CM  CM 

CM 

CM 

*  21  —  Ph  to  to 

co 

> 

co  P-  —  (»  P° 

• 

— >  ptj 

PD 

pa—'  21  pa  PD 

x-v  pa 

•  Pupu  (k- 

» 

to  P. 

pH 

''EhHW  Ph  Ph 

CM  pH 

+  *r  •  * 

CM 

CM  • 

• 

CM  -COP  •  • 

to  • 

O  pi  -  • 

E-t 

PD  . 

» 

CO  »PQ  •  ►  * 

fO  * 

E-<  >  E-  CU  «-< 

-c 

6-h  P,  tO 

o 

<  CM  Ph  •  Ph  H-t 

e-H  Ph  CM 

' 

e-  •  3T  CM 

C5 

•  CM 

P5 

Ph  to  •  o  rrto 

•  CO 

■K-  •  » W 

CM  hh 

*  ► ■< 

Pi 

+  «;  'tn  P>!< 

& 

»  f-,  c_,  p, 

6-h  cO 

61  P- 

M 

rtP  fHt<  6-h  Ph 

frH  04 

CM  tO  •  •  • 

<  • 

^4  •  • 

• 

. . 

CM  6-i  •  *  .» 

a  - 

CM  -  * 

t— <  CM 

«  to 

■Hf 

^  CM  CM 

Ph  C5  CM  CM  CM 

to  cm 

Ph  CM  CM 

\  CM 

—  ^  2:  «*i  to  to 

P  Mi  CO 

M 

«*. 

«J  Ph 

*  ■«; 

«.  PJ  «.  Ph  PD 

«<  pc 

* 

+  (O  pH  P*  Ph 
•  •  •  • 

+  P- 
• 

+  Ph  Ph 
•  • 

P. 

• 

+  Ph  6-h  Ph  Ph  Ph 

«f  Ph  O* 

■  • 

-W«w- 

CM'— 

to—'— 

M*  — 

^  *w»  ‘Mi-  <W>  w 

CM 

CM 

CM 

CM 

CM 

to 

CO 

<  >  ►!  p  p 

x  P  P 

«c  (=> 

<piJ^pp 

— o 

PhhPPP 

Ph  P 

AhSP 

Ph  ea 

PBDt  pa  pa 

p.  »  P- 

PZ<* 

0) 

«*. 

2:  - 

<£2:  «.< 

i;  « 

II  p  p  pH  p. 

II  P* 

ii  p*  p- 

ii  p. 

1*  p.  Ph  Ph  P-  Ph 

II  P>*  P- 

ft  p  p  p  p 

CM  p 

to  P  P 

M<  P 

CM  t-4  i-4 

: 

W  P  p  p  P 

PM 

CM  P 

CM  P  P 

CM  P 

lOtJ  JPIiDhI 

CO  I-D  ►J 

■ 

P.  «  «C  ■< 

O 

(L  «C 

Pi  «.  <*. 

PD  « 

pa  «  ^  «.  «*.  •< 

fC  « 

Ph  O  O  O  CP 

«: 

p.  c> 

Ph  U  U 

Ph  O 

PhUUU  uu 

BOO 

• 

• 

• 

• 

• 

i  ‘ 

If) 

co 

f- 

CD 

O) 

s 

f- 

H 

■#• 

CBS 

■» 

* 

* 

* 

* 

X 

M 

N 

N 

N 

\ 

N 

*-• 

Ph 

a: 

o 

! 

O 

.  1 

CM  CM  CM  CM 

CM 

CM  CM 

CM 

CM  CM  CM  CM  CM 

CM  CM 

CD 

®  r*  CM  tO 

SI 

P  CO 

CO  0)  S  v-<  CM 

to  ^ 

to  to  to  to 

\ 

to 

to  to 

to 

CO  to  M<  *1 

M4  •M4 

tm 

CM  CM  CM  CM 

►4 

D* 

CM 

CM  CM 

CM 

CM  CM  CM  CM  CM 

CM  CM 

i 


\ 

* 

ixs 

o 

o 

p 

— 

H< 

6~> 

< 

o 


to 

\ 

V 

+ 

* 

* 

o 

CO 

E-* 

o 

o 

« 

3k 

3 

6-> 

6-< 

H« 

\ 

H« 

\ 

* 

V 

* 

<  •• 

•  P 

P^"* 

to  •• 

to  •• 

CO  ••*  ••*  «» 

»•  •« 

•  m 

•  «k 

•»  m> 

Hi 

+  to  ^  —  ^ 

■<  H<  —  — * 

«*— - 

<  to 

H* 

»^to  p  to  to 

C5  CO  H<  Hi 

H 

CM 

OH*  tO  tO 

P 

tid-fctor  —to  to 

t-i  pn  —  to  to 

•p  ^ 

H* 

*■<  p  —  xjl  H< 

A. 

«  •  x:  P  P  P 

tnp^pr  P3 

fta 

p 

c/3  P— -  p  p 

• 

*“*  •  A  E“  p.  fc  A- 

•  p  p  p 

*H  P 

p 

•P  A<  P 

tO  P  6-*  •  •  2T  •  • 

+  *x  •  • 

H*  • 

• 

+  «x  •  • 

CM 

^  •  m  p  (x,  •  • 

OP** 

P  . 

•> 

ow  -  - 

e- 

-t  o  -p  to  e-  a.  to 

6-  »  e*  a,  h< 

6-*  Ph  «H 

o 

E-<  >6-  P  tO 

«; 

p  p  o  x:  <<  •  x  to 

e-<  •  x  to 

•  H< 

p 

e->  •  x  h< 

C5 

+  •  W  w  *  -W  « 

■»■  •  -pa « 

*  -  ■< 

w 

#  •  -  p  *« 

CM  *-h 

H<  •^ehp^eha 

*  e-<  s-<  p. 

6h  p 

N 

-E-  E-  P 

E->  to 

CO  H> . 

^  (0  •  •  • 

CM  •  • 

• 

Hi  tO  «  •  • 

^  • 

«:  E"  •  •  •  «  -  • 

^  g-4  •  •  • 

-v  - 

H*  E-<  -  ►  • 

CJ  » 

p«H<tOHipcoto 

«:  «.  H*  H<  H< 

«N  H 

*  CM 

«  H«  tO  tO 

M  h^4 

— -e^to«  x  to  to 

p  cs  H'to  to 

p*f  ^ 

P  c?  HI  H>  HI 

to  H* 

►h  «.  pq  «q  K  35  pc 

H  «.  p  p 

«.  p 

l-H  <  P  P 

+  CO  P  p  A-  fnp  P 

+  «  p  p  p, 

+  p  p 

p 

+  to  P  p,  p 

+  p 

•  •  •  • 

•  • 

• 

•  ♦  •  • 

• 

* - '  - - - - -  ^ 

^(w  w  W 

y  f  *-,,  ' 

p  — 

(O  '■w* 

Hi  — 

CO 

to 

H« 

h< 

<>pppppp 

«q>  iJp  C 

«  PI  R 

«:  p. 

Ht*App 

■<  P 

P  i-  t=>  O  p  DPP 

Ph  »-h  dap 

POP 

P  p 

PhDPP 

P  p 

p  x  •<  «-  x  <<  « 

r  r  <  «. 

x 

PX  m.  m. 

||  p  p  p,  p  p  p,  p 

ii  p,  p  p,  p 

n  p  p 

it  P 

II  p  P  p  p 

II  P 

tO  PS  Pi  PS  ps  pi  ps  pi 

H<  PS  PI  PS  PS 

H 

CM  PS 

tO  PS  PS  ps  PI 

Hi  PI 

to  ps  pi  pi  ps 

h»  ij  pj 

HI  PS 

H*  PS  »-S  P>  PS 

Hi  PI 

p  «  «c  «J  «■  ««  «J  « 

P  «b  «e  ■<  « 

p  «  «; 

p  «c 

P  «*«:«.  « 

PQ  «c 

PhOOOCJ  ooo 

PO  OOO 

POO 

P  U 

APOOO 

P  o 

• 

• 

• 

• 

• 

• 

H 

CM 

to 

H< 

m 

co 

H 

H 

fH 

H 

H 

* 

* 

* 

■«■ 

* 

* 

\ 

\ 

\ 

\ 

\ 

s 

CM  CM  CM  CM  CM  CM  CM 

CM  CM  CM  CM 

CM  CM 

CM 

CM  CM  CM  CM 

CM 

tO  SC  0-  00  OS  CSS  »-l 

CM  to  Hi  m 

to  c- 

00 

01  IS  *H  CM 

to 

HI  HI  HI  HI  HI  in  m 

in  m  in  in 

in  m 

m 

into  to  CO 

CD 

CM  CM  CM  CM  CM  CM  CM 

CM  CM  CM  CM 

CM  CM 

CM 

CO  CM  CO  CM 

CM 

J 


* 

s 

* 

• 

« 

* 

6* 

* 

* 

Z 

* 

* 

3 

* 

* 

£ 

* 

* 

3 

* 

* 

« 

* 

* 

9 

* 

* 

to 

-» 

*  * 

* 

< 

* 

* 

3 

«• 

X  >H 

* 

* 

£ 

«1  X 

* 

* 

-* 

6-61 

N 

* 

3 

# 

3  3 

« 

* 

te 

■» 

3  pa 

3 

# 

6-* 

* 

30 

X 

* 

* 

>H 

Eh 

X 

* 

3 

* 

*  * 

x 

3 

X 

* 

« 

* 

s —  \ 

Eh 

3 

3 

« 

o 

* 

3 

3 

3 

« 

Pm 

* 

3 

3 

» 

pa 

* 

3 

# 

3 

« 

pa 

* 

« 

* 

^4  •* 

* 

« 

cn 

* 

X  — * 

* 

o 

« 

X 

pa  •* 

X 

* 

Em 

* 

X  — 

•-  Eh 

x  •- 

O 

* 

X 

+  «—  x  to 

* 

Pa 

* 

. .  .» 

—  ••  — '  X 

« 

p» 

« 

> — . 

+  <  ^  Eh 

X  Eh— ■  (O  X 

+  «<--'  «C  3 

* 

£  £ 

X  >H 

Eh  P^  Eh  CO 

x  eo  3  3  > 

3  3  3  to 

* 

pa 

« 

XX 

«  < 

X  to  £  CO  pa 

EH  3  £  X  • 

X  CO  £  to  P1 

X 

* 

•  • 

Eh  Eh 

3X33  - 

x  3  3  P<  X 

« 

x 

* 

m.  • 

3  3 

EH  X  Eh  K  • 

3  3  3  *3 

3  X  3  X  • 

* 

6-i 

* 

C5  c5 

Pa  U 

3  •  •  •  » 

3  •  •  -3 

3  •  •  •  — 

* 

to 

* 

33 

3  •  •  “3 

«  •  04  CO 

3  -  “  -3 

* 

* 

pa  w 

•  • 

3  X  3  (X.  gn 

*  X  3  £  3 

p>X  X  04  3 

* 

pa 

« 

£  £ 

m  0. 

<  «  £  to 

X  «  3  X 

X  «  £  CO 

* 

K 

« 

z  to 

pc  po 

*  Eh  £h  3  3 

X  3  3  3  3 

*  Eh  3  3  pa 

* 

E-< 

* 

►H  O 

Eh  EH 

3  3  Eh  X 

X  3  3  •  • 

3  3  3  X 

« 

* 

to  CJ 

to  to 

x  pa  P4  •  • 

3  3  3  -  * 

X  3  3  •  * 

* 

3 

* 

•  • 

pm  pa 

X  3  3  -  - 

3  3  x  X 

X  3  O  -  - 

* 

O 

* 

•  3 

X  X 

x  •  •  x  x 

+  •  -33 

x  •  •  X  X 

tt 

* 

o  o 

.  . 

*  •  Eh  Eh 

*  -CO  to 

*  -  3  3 

» 

Pc 

* 

z  z 

•  — 

+  x  x  to  eo 

3X333 

+  X  X  to  to 

* 

Eh 

* 

p-  &J 

£  £ 

x  x  P<  pa 

3  X  X  X  X 

X  X  3  3 

« 

x 

* 

£  £ 

X  X 

P«*KX 

to  3  3  3  3 

pc  x  X  >~  X 

* 

£ 

* 

•  • 

.  . 

E-«  •  •  •  • 

3  •  •  •  • 

£-<•••• 

* 

►h 

* 

. _ - _ 

w  W'  V--  •w' 

x*— 

^  ' — 

* 

6h 

* 

3 

3 

3 

« 

to 

* 

3  +1 

pa  pa 

X  3  3  3  3 

3  3  3  3 

X  3  3  3  3 

* 

3 

* 

03 

33 

3  &  3  3 

II  9  0  3  3 

3  3  3  3 

« 

* 

£  £ 

to  to 

II  £  £  x  < 

£  £  x  X 

II  £  £  x  X 

* 

£ 

* 

3  Pm 

p«-  Pm 

3  3  3  3 

x  Pm  0-  |k.  Pm 

Pm  3  3  3 

* 

S3 

* 

X 

3 

X 

* 

£ 

* 

33 

3  3 

Eh  3  3  3  3 

CO  3  3  3  3 

3  3  3  3  3 

* 

►m 

* 

►a  3 

3  3 

(03333 

pa  3  3  3 

CO  3  3  3  3 

* 

Eh 

* 

x.  < 

«  < 

3  <  x  x  X 

X  <  X  ■< 

3  «•  x 

* 

Pm 

* 

oo 

O  Cl 

X  CJ  CJ  CJ  CJ 

3  (J  CJ  C  CJ 

X  tj  CJ  CJ  CJ 

* 

O 

* 

* 

* 

* 

* 

N* 

* 

*  * 

N 

1 

CVJtM 

CM  CM 

CM  CM  CM  CM 

CM  CM  CM  CM 

CM  CM  CM  CM 

1 

Hf  IT) 

CO  3 

00  01  cs  3 

cm  to  ■«<  in 

CO  3  00  O 

COCO 

CO  CO 

CO  CO  3  3 

3  3  3  3 

3  3  3  3 

* 

raw 

CM  CM 

CM  CM  CM  CM 

CM  CM  CM  CM 

CM  CM  CM  CM 

1 


123 


/*  VYFST*.  =  7YESTB  +  BYY  *  DFLTAY  +  BYX  *  DELTAX 
280  2  CALL  FMUL  ( . BYY , .BELT AY, .VYESTA) i 

P81  2  C*LL  FMUL  ( .BYX , . DELTA X, .TEMP) » 

28?  2  CALL  FADD  ( .VYESTA ,. TEMP , .VYESTA ) ? 

2e3  2  CALL  FADD  ( .VYESTA, .VYESTB, .VYESTA); 
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295  2  CALL  FSQR  ( . VYESTA$NSVEL, . VYiNSiSQ) J 

296  2  CALL  FADD  t  . VX$EW$SQ, .VY$NS$SQ, .SPEED) 

297  2  CALL  FSQRT  ( .SPEED , .SPEED); 
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